| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| // |
| //////////////////////////////////////////////////////////////////////////////// |
| |
| goog.module('tink.CryptoFormatTest'); |
| goog.setTestOnly('tink.CryptoFormatTest'); |
| |
| const CryptoFormat = goog.require('tink.CryptoFormat'); |
| const {PbKeysetKey: PbKey, PbOutputPrefixType} = goog.require('google3.third_party.tink.javascript.internal.proto'); |
| |
| describe('crypto format test', function() { |
| it('constants', async function() { |
| expect(CryptoFormat.RAW_PREFIX_SIZE).toBe(0); |
| expect(CryptoFormat.NON_RAW_PREFIX_SIZE).toBe(5); |
| expect(CryptoFormat.LEGACY_PREFIX_SIZE).toBe(5); |
| expect(CryptoFormat.TINK_PREFIX_SIZE).toBe(5); |
| |
| expect(CryptoFormat.LEGACY_START_BYTE).toBe(0x00); |
| expect(CryptoFormat.TINK_START_BYTE).toBe(0x01); |
| }); |
| |
| it('get output prefix unknown prefix type', async function() { |
| let key = new PbKey() |
| .setOutputPrefixType(PbOutputPrefixType.UNKNOWN_PREFIX) |
| .setKeyId(2864434397); |
| |
| try { |
| CryptoFormat.getOutputPrefix(key); |
| } catch (e) { |
| expect(e.toString()) |
| .toBe('SecurityException: Unsupported key prefix type.'); |
| return; |
| } |
| fail('An exception should be thrown.'); |
| }); |
| |
| it('get output prefix invalid key id', async function() { |
| // Key id has to be an unsigned 32-bit integer. |
| const invalidKeyIds = [0.2, -10, 2**32]; |
| let key = new PbKey().setOutputPrefixType(PbOutputPrefixType.TINK); |
| |
| const invalidKeyIdsLength = invalidKeyIds.length; |
| for (let i = 0; i < invalidKeyIdsLength; i++) { |
| key.setKeyId(invalidKeyIds[i]); |
| try { |
| CryptoFormat.getOutputPrefix(key); |
| } catch (e) { |
| expect(e.toString()) |
| .toBe( |
| 'InvalidArgumentsException: Number has to be unsigned 32-bit integer.'); |
| continue; |
| } |
| fail('An exception should be thrown for i: ' + i + '.'); |
| } |
| }); |
| |
| it('get output prefix tink', async function() { |
| let key = new PbKey() |
| .setOutputPrefixType(PbOutputPrefixType.TINK) |
| .setKeyId(2864434397); |
| const expectedResult = |
| new Uint8Array([CryptoFormat.TINK_START_BYTE, 0xAA, 0xBB, 0xCC, 0xDD]); |
| |
| const actualResult = CryptoFormat.getOutputPrefix(key); |
| expect(actualResult).toEqual(expectedResult); |
| }); |
| |
| it('get output prefix legacy', async function() { |
| let key = new PbKey() |
| .setOutputPrefixType(PbOutputPrefixType.LEGACY) |
| .setKeyId(16909060); |
| const expectedResult = new Uint8Array( |
| [CryptoFormat.LEGACY_START_BYTE, 0x01, 0x02, 0x03, 0x04]); |
| |
| const actualResult = CryptoFormat.getOutputPrefix(key); |
| expect(actualResult).toEqual(expectedResult); |
| }); |
| |
| it('get output prefix raw', async function() { |
| let key = new PbKey() |
| .setOutputPrefixType(PbOutputPrefixType.RAW) |
| .setKeyId(370491921); |
| const expectedResult = new Uint8Array(0); |
| |
| const actualResult = CryptoFormat.getOutputPrefix(key); |
| expect(actualResult).toEqual(expectedResult); |
| }); |
| }); |