Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add autoware_version_manager package #80

Closed
wants to merge 11 commits into from

Conversation

xmfcx
Copy link
Contributor

@xmfcx xmfcx commented Jul 14, 2023

Description

Continuation of discussion in:

Related to (depends on):

Related issue:

Tests performed

You should merge:

before testing.

Compile and run it with:

$ ros2 launch autoware_version_manager autoware_version_manager.launch.xml
[autoware_version_manager_exe-1] [INFO 1689353411.197970986] [autoware_version_manager]: Autoware version: 2023.07.0 (AutowareVersionManagerNode() at /home/mfc/projects/autoware/src/core/autoware.core/autoware_version_manager/src/autoware_version_manager_core.cpp:54)
[autoware_version_manager_exe-1] [INFO 1689353411.198022887] [autoware_version_manager]: Component interface version: 1.0.0 (AutowareVersionManagerNode() at /home/mfc/projects/autoware/src/core/autoware.core/autoware_version_manager/src/autoware_version_manager_core.cpp:58)

You can call the services:

$ ros2 service call /get_version_autoware autoware_system_msgs/srv/GetVersionAutoware
requester: making request: autoware_system_msgs.srv.GetVersionAutoware_Request()

response:
autoware_system_msgs.srv.GetVersionAutoware_Response(year=2023, month=7, micro=0)

$ ros2 service call /get_version_component_interface autoware_system_msgs/srv/GetVersionComponentInterface
requester: making request: autoware_system_msgs.srv.GetVersionComponentInterface_Request()

response:
autoware_system_msgs.srv.GetVersionComponentInterface_Response(major=1, minor=0, patch=0)

Pre-review checklist for the PR author

The PR author must check the checkboxes below when creating the PR.

In-review checklist for the PR reviewers

The PR reviewers must check the checkboxes below before approval.

Post-review checklist for the PR author

The PR author must check the checkboxes below before merging.

  • There are no open discussions or they are tracked via tickets.

After all checkboxes are checked, anyone who has write access can merge the PR.

@xmfcx xmfcx added the enhancement New feature or request label Jul 14, 2023
@xmfcx xmfcx requested a review from isamu-takagi July 14, 2023 10:37
@xmfcx xmfcx self-assigned this Jul 14, 2023
@xmfcx
Copy link
Contributor Author

xmfcx commented Jul 14, 2023

(Edited after revision)
@isamu-takagi do you think we can go with following versioning schemes?

# Autoware version (CalVer with YYYY.0M.MICRO)
# https://calver.org/#scheme
autoware-version:
  year: 2023
  month: 7
  micro: 0

# Autoware component interface version (SemVer)
# https://semver.org/
component-interface-version:
  major: 1
  minor: 0
  patch: 0
// Autoware version (CalVer with YYYY.0M.MICRO)
// https://calver.org/#scheme
struct VersionAutoware
{
  uint16_t year;   // year of release
  uint16_t month;  // month of release
  uint16_t micro;  // increments for bug fixes or patches
};

// Autoware component interface version (SemVer)
// https://semver.org/
struct VersionInterface
{
  uint16_t major;  // increments for breaking changes
  uint16_t minor;  // increments for non-breaking changes
  uint16_t patch;  // increments for bug fixes or patches
};

@xmfcx
Copy link
Contributor Author

xmfcx commented Jul 14, 2023

@mitsudome-r I've edited this post a couple of times to avoid confusion.

The current versioning scheme YYYY.0M has served us well so far, but with the increasing pace of development, it might be beneficial to refine it further.

Looking at different versioning schemes, I suggest we adopt a slightly modified approach for Autoware: YYYY.0M.MICRO. This scheme retains the clarity of our previous system, while also enabling us to track and version hotfixes.

Under this system, the YYYY.0M part will strictly represent the release date, devoid of any additional information, and the MICRO part will specify the hotfixes made on that release.

To deal with breaking changes, it might make sense to decouple the Component Interface version from the Autoware version. This would simplify tracking of breaking changes, as they would be tied to the Component Interface version, which could follow SemVer.

What is a breaking change for Autoware?

In the context of Autoware, I believe we need a clear definition of "breaking change".
I think that a breaking change would be anything that alters the Component Interface version, affecting compatibility.

The concept of breaking changes could extend to dropping support for certain sensors, but since we aim to maintain sensor manufacturer neutrality in Autoware, these changes wouldn't impact the Autoware version. This way, we maintain a clean distinction between the interfaces and the core system.

Looking forward to hearing your thoughts on these suggestions.

Some ideas generated by ChatGPT for a breaking change (not that it will affect the versioning system mentioned above)

Breaking Changes

  1. Changes to the API: Any significant changes to the software's Application Programming Interface (API) could constitute a breaking change. If a function's parameters, return values, or behavior is altered in a way that existing code will no longer work correctly, this would be a breaking change.

  2. Altering Core Functionality: If a key feature or functionality of the software changes drastically enough that it requires users to modify how they interact with the software, this could be considered a breaking change. For example, changes in the driving or mapping algorithms that would require a significant recalibration or reconfiguration.

  3. Deprecation of Features: If a feature or component that users depend on is removed, it could constitute a breaking change. For example, dropping support for certain communication protocols or sensor interfaces that some users rely on.

  4. Dependency Updates: If Autoware depends on other software libraries, and those dependencies are upgraded in a way that requires the user to also upgrade those dependencies, this could be considered a breaking change.

  5. Changes in System Requirements: If newer versions of Autoware require different or more advanced hardware or software environments (e.g., newer OS, higher compute resources), that could be a breaking change for users with existing setups.

  6. Significant Changes in Configuration or Installation Process: Changes that alter how Autoware is installed, set up, or configured might be considered breaking changes if they require users to significantly adjust their processes.

  7. Incompatible Data Format Changes: Changes to the formats of data that Autoware imports or exports could be a breaking change if they're not backwards compatible.

@xmfcx xmfcx force-pushed the feat/add-autoware-version-manager branch from 517ee08 to 85490dc Compare July 14, 2023 14:37
@xmfcx xmfcx marked this pull request as ready for review July 14, 2023 17:43
@xmfcx
Copy link
Contributor Author

xmfcx commented Jul 14, 2023

@isamu-takagi -san this PR is ready for review, after the review, I will populate the readme file with instructions.

I am open to any kind of suggestions, version schemes, the way they are stored, fetched, anything basically.

Thanks for reviewing.

Signed-off-by: M. Fatih Cırıt <[email protected]>
@HansRobo
Copy link
Member

This package is great for getting the version at runtime!
On the other hand, some software can write more efficient and cleaner code by getting the version at compile time.

So how about generating hpp files based on version-autoware.yaml and version-component-interface.yaml when building this package?

Note: It's fine to separate the implementation of this proposal from this pull-request.

@isamu-takagi
Copy link

I think it's good to manage versions for each component/scope. For example, even if the interface for the vehicle driver changes, the sensor driver want to keep the version.

M. Fatih Cırıt and others added 2 commits July 19, 2023 18:43
Signed-off-by: M. Fatih Cırıt <[email protected]>
@xmfcx xmfcx force-pushed the feat/add-autoware-version-manager branch from 54b1e93 to 82bfb89 Compare July 20, 2023 12:39
Signed-off-by: M. Fatih Cırıt <[email protected]>
@xmfcx xmfcx force-pushed the feat/add-autoware-version-manager branch from 82bfb89 to 2bc885a Compare July 20, 2023 12:41
Signed-off-by: M. Fatih Cırıt <[email protected]>
@xmfcx
Copy link
Contributor Author

xmfcx commented Jul 21, 2023

@HansRobo @isamu-takagi Now I am working on an implementation for generating the version header files. For this, I will restructure this package as follows:

  • autoware_version_manager (folder)
    • autoware_version_manager (package, will serve the services)
    • version_header_generator (package, will be used to generate the headers)

version_header_generator

This package will contain the jinja2 templates and the python executables that will generate the headers.

These will read the version .yaml files to generate the headers.

Will be similar to generate_parameter_library_py in functional sense.

autoware_version_manager

This package will call the executables of version_header_generator in compilation time using custom cmake functions, similar to generate_parameter_library.cmake.

The generated headers will be shared with outside nodes from this package.

And in the runtime, it will use the version information from the generated headers and serve this information to other nodes.

Do you think this is a good structure/plan to implement this?

@xmfcx
Copy link
Contributor Author

xmfcx commented Jul 21, 2023

I think it's good to manage versions for each component/scope. For example, even if the interface for the vehicle driver changes, the sensor driver want to keep the version.

@isamu-takagi I think it's a good idea but also challenging to implement.

We should define what Autoware really uses for each interface. (For each component.) (autoware_x_msgs, autoware_auto_x_msgs, tier4_autoware_msgs etc.)

Edit: I've just seen your work on this topic:

Until then I suggest we start with a large scope version for the interface. What do you think?

@xmfcx
Copy link
Contributor Author

xmfcx commented Jul 25, 2023

@stale
Copy link

stale bot commented Sep 23, 2023

This pull request has been automatically marked as stale because it has not had recent activity.

@stale stale bot added the stale label Sep 23, 2023
@xmfcx
Copy link
Contributor Author

xmfcx commented Mar 7, 2024

I'm closing all of my message migration PRs.

@xmfcx xmfcx closed this Mar 7, 2024
@xmfcx xmfcx deleted the feat/add-autoware-version-manager branch July 19, 2024 11:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request stale
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants