summaryrefslogtreecommitdiffhomepage
path: root/packages/browser/src/methods/startRegistration.test.ts
diff options
context:
space:
mode:
authorMatthew Miller <matthew@millerti.me>2023-06-25 11:16:24 -0700
committerGitHub <noreply@github.com>2023-06-25 11:16:24 -0700
commit67aad754c531a53bc0f9915ebdfc0e995df74a47 (patch)
tree9bf7c563778134b2e8b8df1c423f04d7e216ff37 /packages/browser/src/methods/startRegistration.test.ts
parentba4ce17cbc5e6aed06e8b909f47784ccd06c78d8 (diff)
parent5787bb38d60bda3bcada741353016ca328f116f0 (diff)
Merge pull request #400 from MasterKale/feat/json-type-updatesm7n-openwrtopenwrt
feat/json-type-updates
Diffstat (limited to 'packages/browser/src/methods/startRegistration.test.ts')
-rw-r--r--packages/browser/src/methods/startRegistration.test.ts50
1 files changed, 50 insertions, 0 deletions
diff --git a/packages/browser/src/methods/startRegistration.test.ts b/packages/browser/src/methods/startRegistration.test.ts
index debaba3..e27099d 100644
--- a/packages/browser/src/methods/startRegistration.test.ts
+++ b/packages/browser/src/methods/startRegistration.test.ts
@@ -250,6 +250,56 @@ test('should return authenticatorAttachment if present', async () => {
expect(response.authenticatorAttachment).toEqual('cross-platform');
});
+test('should return convenience values if getters present', async () => {
+ /**
+ * I call them "convenience values" because the getters for public key algorithm,
+ * public key bytes, and authenticator data are alternative ways to access information
+ * that's already buried in the response.
+ */
+ // Mock extension return values from authenticator
+ mockNavigatorCreate.mockImplementation((): Promise<any> => {
+ return new Promise(resolve => {
+ resolve({
+ response: {
+ getPublicKeyAlgorithm: () => 777,
+ getPublicKey: () => new Uint8Array([0, 0, 0, 0]).buffer,
+ getAuthenticatorData: () => new Uint8Array([0, 0, 0, 0]).buffer,
+ },
+ getClientExtensionResults: () => { },
+ });
+ });
+ });
+
+ const response = await startRegistration(goodOpts1);
+
+ expect(response.response.publicKeyAlgorithm).toEqual(777);
+ expect(response.response.publicKey).toEqual('AAAAAA');
+ expect(response.response.authenticatorData).toEqual('AAAAAA');
+});
+
+test('should not return convenience values if getters missing', async () => {
+ /**
+ * I call them "convenience values" because the getters for public key algorithm,
+ * public key bytes, and authenticator data are alternative ways to access information
+ * that's already buried in the response.
+ */
+ // Mock extension return values from authenticator
+ mockNavigatorCreate.mockImplementation((): Promise<any> => {
+ return new Promise(resolve => {
+ resolve({
+ response: {},
+ getClientExtensionResults: () => { },
+ });
+ });
+ });
+
+ const response = await startRegistration(goodOpts1);
+
+ expect(response.response.publicKeyAlgorithm).toBeUndefined();
+ expect(response.response.publicKey).toBeUndefined();
+ expect(response.response.authenticatorData).toBeUndefined();
+});
+
describe('WebAuthnError', () => {
describe('AbortError', () => {
const AbortError = generateCustomError('AbortError');