-
Notifications
You must be signed in to change notification settings - Fork 16
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
Fix phase2 failures and improve QA #26
Merged
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
It seems I was too fast and its probably that sed-fu triggering this. |
ynezz
force-pushed
the
ynezz/fix-p2-checksum-step
branch
from
December 23, 2023 07:38
4f1be05
to
a6584b2
Compare
Please don't reformat phase2 yet. It's only going to make my work harder. Let's save that for "the end" as we did on phase1. Thx |
ynezz
force-pushed
the
ynezz/fix-p2-checksum-step
branch
from
December 24, 2023 09:36
a6584b2
to
15ed62a
Compare
ynezz
changed the title
Fix checksum step failure in phase2 and improve QA
Fix phase2 failures and improve QA
Dec 24, 2023
ynezz
force-pushed
the
ynezz/fix-p2-checksum-step
branch
from
December 24, 2023 13:18
d3868b4
to
e8bfef1
Compare
@f00b4r0 can you check the proposed fixes? |
Fixes following error: File 'sha2rsync.pl' not available at master Fixes: c3ddb0d ("phase2: use sha2rsync.pl for 'targetupload'") Signed-off-by: Petr Štetiar <[email protected]>
Due to the stray closing parenthesis introduced in commit f0faed2 ("phase2: compute checksums") we have currently we've failing checksum step in phase2: argv: b'cd bin/packages/mipsel_24kc_24kf; find . -type f -not -name \'sha256sums\' -printf "%P\n" | sort | xargs -r ../../../staging_dir/host/bin/mkhash -n sha256 | sed -ne \'s!^\\(.*\\) \\(.*\\)$!\x01 *\x02!p\' > sha256sums)' environment: ...snip... using PTY: False /bin/sh: 2: Syntax error: ")" unexpected program finished with exit code 2 Fixes: f0faed2 ("phase2: compute checksums") Reported-by: Hannu Nyman <[email protected]> Signed-off-by: Petr Štetiar <[email protected]>
flake8 is a Python tool that glues together pycodestyle, pyflakes, mccabe, and third-party plugins to check the style and quality of some Python code. Currently we've issue in phase2 in checksum step: /bin/sh: 2: Syntax error: ")" unexpected And it seems, that flake8 is able to spot places which might lead to such issues during runtime: phase2/master.cfg:733:151: W605 invalid escape sequence '\(' phase2/master.cfg:733:155: W605 invalid escape sequence '\)' phase2/master.cfg:733:158: W605 invalid escape sequence '\(' phase2/master.cfg:733:162: W605 invalid escape sequence '\)' So lets enable flake8 checking on the CI so we can spot similar places in the future and address them before deployment. We dont want to make current ongoing work on phase2 code harder, thus we don't touch that part yet, so we whitelist most of the checks for now. References: f0faed2 ("phase2: compute checksums") Signed-off-by: Petr Štetiar <[email protected]>
To make it more readable, diffs smaller, easier to review etc. Signed-off-by: Petr Štetiar <[email protected]>
Resolved a flake8 linting warning related to an invalid escape sequence in the ShellCommand for calculating checksums: phase2/master.cfg:739:28: W605 invalid escape sequence '\(' phase2/master.cfg:739:32: W605 invalid escape sequence '\)' phase2/master.cfg:739:35: W605 invalid escape sequence '\(' phase2/master.cfg:739:39: W605 invalid escape sequence '\)' The warning was caused by the use of unescaped parentheses in a regular expression within a sed command. Use a raw string (with an 'r' prefix) to treat backslashes as literal characters, ensuring that the regular expression is correctly interpreted and flake8 does not raise a warning. This fix ensures that the code adheres to Python's string handling best practices and maintains the integrity of the regular expression functionality. Fixes: f0faed2 ("phase2: compute checksums") Signed-off-by: Petr Štetiar <[email protected]>
Fix ruff's recommendation: phase2/master.cfg:328:16: E721 Do not compare types, use `isinstance()` "Unlike a direct type comparison, isinstance will also check if an object is an instance of a class or a subclass thereof." Signed-off-by: Petr Štetiar <[email protected]>
Currently `buildlist` step fails with following: ../../../sha2rsync.pl ../../arch-sha256sums bin/packages/aarch64_generic/sha256sums rsynclist in dir /builder/aarch64_generic/build/sdk (timeout 1200 secs) watching logfiles {} argv: [b'../../../sha2rsync.pl', b'../../arch-sha256sums', b'bin/packages/aarch64_generic/sha256sums', b'rsynclist'] environment: ... PWD=/builder/aarch64_generic/build/sdk ... Upon execvpe b'../../../sha2rsync.pl' [b'../../../sha2rsync.pl', b'../../arch-sha256sums', b'bin/packages/aarch64_generic/sha256sums', b'rsynclist'] in environment id 139847367136832 :Traceback (most recent call last): ... FileNotFoundError: [Errno 2] No such file or directory: b'../../../sha2rsync.pl' due to relative paths being off by one: worker work dir = /builder/aarch64_cortex-a72/build workerdest = "../sha2rsync.pl" is absolute path /builder/aarch64_cortex-a72/sha2rsync.pl thus relative path from: FileNotFoundError: [Errno 2] No such file or directory: b'../../../sha2rsync.pl' in following context: PWD=/builder/aarch64_generic/build/sdk b'../../../sha2rsync.pl' is wrong absolute path `/builder/sha2rsync.pl` by one directory level, thus adjust all those paths accordingly. Fixes: c3ddb0d ("phase2: use sha2rsync.pl for 'targetupload'") Signed-off-by: Petr Štetiar <[email protected]>
ynezz
force-pushed
the
ynezz/fix-p2-checksum-step
branch
from
April 13, 2024 04:13
e312f11
to
fe54cb8
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Due to the stray
)
in commit f0faed2 ("phase2: compute checksums") we have currently we've failing checksum step in phase2:so lets fix it and as well try to detect such regressions in the future by improving the QA in the CI pipeline.
It seems, that
flake8
is able to spot this issues: