-
Notifications
You must be signed in to change notification settings - Fork 277
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
Add lock argument along with the actual building process #2512
Comments
There's a bit of misunderstanding above re:the lock option. It was designed to solve a different problem. We have a parallel build process that builds x64 and amd64 in parallel. Let's say the input manifest ref for common-utils is The
This also makes #2473 a lot simpler, since one of the parts of that workflow checks out every component and tries to find its HEAD commit ID. That will be already known from the manifest lock above. |
@zelinh Is this issue still valid? Looks like we already have build and bundle manifest with exact commits for all builds (incremental and otherwise). With continue-on-error option, the build never fails except for mandatory components. |
I think this request should still be valid. When the build failed, we don't have a mechanism or platform to showcase the commit ID that build job is failing at when the input manifest using branch as reference. |
Is your feature request related to a problem? Please describe
Problem statement
For our build dashboards, we are displaying the running status of each
distribution build
along with the head commit for each plugins included in the workflow. The way we getting the commit ID right now is by checking out into each plugin's repo on certain branch and getting the head commit within the build workflow process.There might be a discrepancy for the commit ID if people pushing any commit when the build workflow is actively running. For example, our dashboard would display the current head commit has been updated with the latest push but the building process didn't actually pick that change.
We were thinking to use the commit IDs from the build manifest. When the distribution build workflow succeeds, it will create two different manifest:
build manifest
&bundle/distribution manifest
, both of them will contain the commit ID for each components which shows the HEAD commits this current build job pick for every components in the manifest.However, when the job fails, these manifests won't be created so people wouldn't know the head commit of each components current job is picking on and which caused the job failing. These commit IDs could be useful for maintainer to keep track of the build status and help them debug when error occurs, but currently we don't have a mechanism to display the commit IDs workflow is picking when distribution build Jenkins workflow ends up failure.
Existing feature
Currently we have
lock
option in our building script by running./build.sh --lock $MANIFEST
https://github.com/opensearch-project/opensearch-build/tree/main/src/build_workflow#avoiding-rebuilds
The function of this option right now is to generate a
$MANIFEST.lock
file with stable git references (commit IDs) and build options including its architecture, platform and etc.. Basically it replaces theref
in the input manifest from branch to commit id and return;opensearch-build/src/run_build.py
Lines 28 to 39 in 7b61ab4
However the
lock
wouldn't trigger the actual building process and we won't know about the results status (success or failure) of the building process with these certain commits.Describe the solution you'd like
We could elaborate more on the
lock
option. We could add thislock
into our actual building process instead of just generating the lock file.In this way, when the
lock
argument is enabled, the build process will always go on and, at the same time the lock file will also be generated showing the correct stable git references current building process is on.Describe alternatives you've considered
No response
Additional context
No response
The text was updated successfully, but these errors were encountered: