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

Add tests for passwdqc pwqcheck #41

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open

Conversation

Zaiba-S
Copy link

@Zaiba-S Zaiba-S commented Feb 7, 2025

Currently, there are no tests implemented for the package, so this serves as an initial attempt to implement basic testing coverage.
This PR introduces an initial set of tests for the pwqcheck binary of the passwdqc package.

Any feedback or suggestions would be appreciated.

Copy link
Member

@solardiz solardiz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for the contribution. Yes, we need tests.

Makefile Outdated
@@ -307,6 +307,17 @@ remove_lib_wrapped:
remove_locales_wrapped:
for f in $(LANGUAGES); do $(RM) $(DESTDIR)$(LOCALEDIR)/$$f/LC_MESSAGES/$(PACKAGE).mo; done

test:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we want this target called check, and it should exit non-zero on any test failures.

And we should run it from GitHub Actions, but that may be a separate PR or at least separate commit.

@echo "Running tests..."
# Set LD_LIBRARY_PATH to include the current directory
@export LDFLAGS="-Wl,-rpath,$(CURDIR)"; \
export LD_LIBRARY_PATH=$(CURDIR):$$LD_LIBRARY_PATH; \
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this is excessive. For my manual testing, I simply set LD_LIBRARY_PATH=. and it just works.

The change of LDFLAGS wouldn't take effect at this point anyway, because the test scripts being invoked from here assume the tool has already been built.

@solardiz
Copy link
Member

solardiz commented Feb 9, 2025

My thinking was to start with what I've been doing in manual testing - running pwqcheck on a large file and confirming the hash of its output isn't unexpectedly changed. This wouldn't directly test the individual checks, but it would ensure stable behavior. So if we ever make code changes that change the behavior on such large test input, we'll need to explicitly acknowledge this and update the hash. A drawback is the large input file would need to be stored somewhere in here or download from somewhere external (e.g., the run/password.lst file we have in the john repo) or reproducibly generated.

$ LD_LIBRARY_PATH=. ./pwqcheck -1 --multi < ~/john/run/password.lst | grep -c ^OK:
1733
$ LD_LIBRARY_PATH=. ./pwqcheck -1 --multi < ~/john/run/password.lst | grep -c ^Bad
1793975
$ LD_LIBRARY_PATH=. ./pwqcheck -1 --multi < ~/john/run/password.lst | md5sum 
3eccb6ef49eb84b494c61954c240e76c  -

I see that you also test a few features that the above would not.

test_basic_password " " "fail" "Single space"
test_basic_password "" "fail" "Empty password"
test_basic_password "$(printf 'a%.0s' {1..71})" "fail" "Very long password"
test_basic_password "ljy8zk9aBJ3hA3TXAAMAQe61ytFohJM4SuPFbA4L1xDqV2JDE1n8BCnLN96evcJMWyTkr9y3" "pass" "Max lenght password"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Typo: lenght.

Also, if we do these tests, there should probably be one for a password that's just above max length, with expected fail.

Also, shouldn't we expect specific fail reasons?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the review !

  • I will correct the typo and add test case for a password just above the max length and ensure it fails as expected.

  • Reagarding the fail reason,Could you please clarify if you are expecting specific fail reasons for each test case?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • Reagarding the fail reason,Could you please clarify if you are expecting specific fail reasons for each test case?

Yes, like you already have in another script where you check against expected output. Instead of the word fail, you could include those reason strings.

@Zaiba-S
Copy link
Author

Zaiba-S commented Feb 12, 2025

My thinking was to start with what I've been doing in manual testing - running pwqcheck on a large file and confirming the hash of its output isn't unexpectedly changed. This wouldn't directly test the individual checks, but it would ensure stable behavior. So if we ever make code changes that change the behavior on such large test input, we'll need to explicitly acknowledge this and update the hash. A drawback is the large input file would need to be stored somewhere in here or download from somewhere external (e.g., the run/password.lst file we have in the john repo) or reproducibly generated.

$ LD_LIBRARY_PATH=. ./pwqcheck -1 --multi < ~/john/run/password.lst | grep -c ^OK:
1733
$ LD_LIBRARY_PATH=. ./pwqcheck -1 --multi < ~/john/run/password.lst | grep -c ^Bad
1793975
$ LD_LIBRARY_PATH=. ./pwqcheck -1 --multi < ~/john/run/password.lst | md5sum 
3eccb6ef49eb84b494c61954c240e76c  -

I see that you also test a few features that the above would not.

Thanks for sharing your approach
Your method of hashing the output of pwqcheck on a large input file sounds like a great way to ensure stability across changes.
Are you suggesting that we implement this approach in addition to the individual tests I proposed?
If so, For storing the large input file and expected output hash for comparison, do you have a preference on where it should be stored ?

@solardiz
Copy link
Member

This PR currently fails our whitespace-errors test:


Run git diff-index --check --cached 4b825dc642cb6eb9a060e54bf8d69288fbee4904
tests/test-pwqcheck-length.sh:14: trailing whitespace.
+    
tests/test-pwqcheck-length.sh:18: trailing whitespace.
+    
tests/test-pwqcheck-length.sh:22: trailing whitespace.
+    
tests/test-pwqcheck-multi.sh:13: trailing whitespace.
+    
tests/test-pwqcheck-multi.sh:16: trailing whitespace.
+    
tests/test-pwqcheck-multi.sh:25: trailing whitespace.
+    
tests/test-pwqcheck-multi.sh:39: trailing whitespace.
+    
tests/test-pwqcheck-multi.sh:85: trailing whitespace.
+  
tests/test-pwqcheck-multi.sh:109: trailing whitespace.
+            echo "StrongP@ss${i}!" 
tests/test-pwqcheck-multi.sh:111: trailing whitespace.
+            echo "weak${i}" 
tests/test-pwqcheck-similarity.sh:94: new blank line at EOF.

@solardiz
Copy link
Member

Are you suggesting that we implement this approach in addition to the individual tests I proposed?

In general, yes. In this same PR, no.

If so, For storing the large input file and expected output hash for comparison, do you have a preference on where it should be stored ?

Currently no. I'd like to hear from @ldv-alt on this. Off the top of my head, the options are:

  1. In this repo and included in release archive (so that make check can use it from there as well).
  2. In this repo, but excluded from release archive (available for use in GitHub Actions).
  3. External reference (what kind?) to john/run/password.lst.
  4. Generate a large list into a pipe programmatically (the lines wouldn't look so much like real passwords, but that's OK if we're only testing stability).

@solardiz
Copy link
Member

The color output could be undesired when redirected to a build log file. I suggest to use color only when outputting to a tty, which I think you can test with test -t 1, e.g. if [ -t 1 ]; then.

We use 8-wide tabs for indentation in this source tree, and I think it makes sense to continue with this style for the shell scripts in here as well (not switch to 4 spaces).

exit_code=$?

if [[ "$expected" == "pass" && $exit_code -eq 0 ]] || \
[[ "$expected" == "fail" && $exit_code -ne 0 ]]; then
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This could be more portable (to other shells) if written as a test expression (so in single brackets and using -a and -o for AND and OR) rather than as two bash conditional expressions.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should we set the default shell to sh instead of bash?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We could, if we actually test these scripts with non-bash as well.

@solardiz
Copy link
Member

Please also add your copyright statements and references to LICENSE as source code comments near the start of your scripts, similarly to how we have this in existing source files.

@solardiz
Copy link
Member

This PR currently fails our whitespace-errors test:

Run git diff-index --check --cached 4b825dc642cb6eb9a060e54bf8d69288fbee4904

This is still failing. You can run the above git command on your computer to see (and then fix) these errors before you push.

Signed-off-by: Zaiba Sanglikar <[email protected]>
Signed-off-by: Zaiba Sanglikar <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

2 participants