From 3ba564ca9f2c5d894a9ef7ef6b827d95e21d2104 Mon Sep 17 00:00:00 2001 From: Tad Fisher Date: Sat, 12 Feb 2022 19:15:05 -0800 Subject: Handle otpauth:// URIs with port numbers --- test/code.t | 20 ++++++++++++++++++++ test/insert.t | 8 ++++++++ test/validate.t | 15 ++++++++++++++- 3 files changed, 42 insertions(+), 1 deletion(-) (limited to 'test') diff --git a/test/code.t b/test/code.t index 19b4754..1752d77 100755 --- a/test/code.t +++ b/test/code.t @@ -65,4 +65,24 @@ EOF [[ $("$PASS" show passfile) == "$expected" ]] ' +test_expect_success 'Generates TOTP code for URI with port number' ' + uri="otpauth://totp/Example:alice@domain.com:443?secret=JBSWY3DPEHPK3PXP&issuer=Example" + + test_pass_init && + "$PASS" otp insert passfile <<< "$uri" && + code=$("$PASS" otp passfile) && + [[ ${#code} -eq 6 ]] +' + +test_expect_success 'Generates HOTP code for URI with port number' ' + uri="otpauth://hotp/Example:alice@google.com:443?secret=JBSWY3DPEHPK3PXP&counter=10&issuer=Example" + inc="otpauth://hotp/Example:alice@google.com:443?secret=JBSWY3DPEHPK3PXP&counter=11&issuer=Example" + + test_pass_init && + "$PASS" otp insert passfile <<< "$uri" && + code=$("$PASS" otp passfile) && + [[ ${#code} -eq 6 ]] && + [[ $("$PASS" otp uri passfile) == "$inc" ]] +' + test_done diff --git a/test/insert.t b/test/insert.t index 938a6dd..b9a3009 100755 --- a/test/insert.t +++ b/test/insert.t @@ -157,4 +157,12 @@ test_expect_success 'Allow multiple levels in path prefix' ' echo [[ $("$PASS" show totp/pass-test/Example/alice@google.com) == "$uri" ]] ' +test_expect_success 'Insert TOTP URI with port number' ' + uri="otpauth://totp/Example:alice@google.com:443?secret=JBSWY3DPEHPK3PXP&issuer=Example" + + test_pass_init && + "$PASS" otp insert passfile <<< "$uri" && + [[ $("$PASS" show passfile) == "$uri" ]] +' + test_done diff --git a/test/validate.t b/test/validate.t index 6d05fdf..13c6049 100755 --- a/test/validate.t +++ b/test/validate.t @@ -5,7 +5,8 @@ export test_description='Tests pass otp URI parsing' . ./setup.sh test_expect_success 'Parses a basic TOTP URI' ' - "$PASS" otp validate "otpauth://totp/Example:alice@google.com?secret=JBSWY3DPEHPK3PXP&issuer=Example" + "$PASS" otp validate "otpauth://totp/Example:alice@google.com?secret=JBSWY3DPEHPK3PXP&issuer=Example" + echo $otp_type ' test_expect_success 'Parses a complex TOTP URI' ' @@ -28,4 +29,16 @@ test_expect_success 'Fails for missing counter' ' test_must_fail "$PASS" otp validate otpauth://hotp?secret=HXDMVJECJJWSRB3HWIZR4IFUGFTMXBOZ ' +test_expect_success 'Parses TOTP URI with port number' ' + "$PASS" otp validate "otpauth://totp/Example:alice@google.com:443?secret=JBSWY3DPEHPK3PXP&issuer=Example" +' + +test_expect_success 'Parses a complex TOTP URI with port number' ' + "$PASS" otp validate otpauth://totp/ACME%20Co:john.doe@email.com:443?secret=HXDMVJECJJWSRB3HWIZR4IFUGFTMXBOZ&issuer=ACME%20Co&algorithm=SHA1&digits=6&period=30 +' + +test_expect_success 'Parses a HOTP URI with port umber' ' + "$PASS" otp validate "otpauth://hotp/Example:alice@google.com:443?secret=JBSWY3DPEHPK3PXP&counter=10&issuer=Example" +' + test_done -- cgit v1.2.3