utils-test.js
4.58 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
'use strict';
var assert = require('assert');
var des = require('../');
var utils = des.utils;
var fixtures = require('./fixtures');
var bin = fixtures.bin;
describe('utils', function() {
describe('IP', function() {
it('should permute properly', function() {
var out = new Array(2);
var inp = [
bin('00000001 00100011 01000101 01100111'),
bin('10001001 10101011 11001101 11101111')
];
utils.ip(inp[0], inp[1], out, 0);
var expected = [
bin('11001100 00000000 11001100 11111111'),
bin('11110000 10101010 11110000 10101010')
];
assert.deepEqual(out, expected);
});
it('should rev-permute properly', function() {
var out = new Array(2);
var inp = [
bin('11001100 00000000 11001100 11111111'),
bin('11110000 10101010 11110000 10101010')
];
utils.rip(inp[0], inp[1], out, 0);
var expected = [
bin('00000001 00100011 01000101 01100111'),
bin('10001001 10101011 11001101 11101111')
];
assert.deepEqual(out, expected);
});
});
describe('PC1', function() {
it('should permute properly', function() {
var out = new Array(2);
var inp = [
bin('00010011 00110100 01010111 01111001'),
bin('10011011 10111100 11011111 11110001')
];
utils.pc1(inp[0], inp[1], out, 0);
var expected = [
bin('1111000 0110011 0010101 0101111'),
bin('0101010 1011001 1001111 0001111')
];
assert.deepEqual(out, expected);
});
});
describe('r28shl', function() {
it('should shl properly', function() {
assert.equal(utils.r28shl(bin('1111000011001100101010101111'), 1),
bin('1110000110011001010101011111'));
assert.equal(utils.r28shl(bin('0101010101100110011110001111'), 1),
bin('1010101011001100111100011110'));
assert.equal(utils.r28shl(bin('1111000011001100101010101111'), 4),
bin('0000110011001010101011111111'));
assert.equal(utils.r28shl(bin('0101010101100110011110001111'), 4),
bin('0101011001100111100011110101'));
});
});
describe('PC2', function() {
it('should permute properly', function() {
var out = new Array(2);
var inp = [
bin('1110000 1100110 0101010 1011111'),
bin('1010101 0110011 0011110 0011110')
];
utils.pc2(inp[0], inp[1], out, 0);
var expected = [
bin('000110 110000 001011 101111'),
bin('111111 000111 000001 110010')
];
assert.deepEqual(out, expected);
});
});
describe('readUInt32BE', function() {
it('should read number properly', function() {
var a = [ 0xde, 0xad, 0xbe, 0xef ];
var o = utils.readUInt32BE(a, 0);
assert.equal(o, 0xdeadbeef);
});
});
describe('writeUInt32BE', function() {
it('should read number properly', function() {
var a = [ 0, 0, 0, 0 ];
utils.writeUInt32BE(a, 0xdeadbeef, 0);
var expected = [ 0xde, 0xad, 0xbe, 0xef ];
assert.deepEqual(a, expected);
});
});
describe('expand', function() {
it('should expand', function() {
var out = [ 0, 0 ];
utils.expand(bin('1111 0000 1010 1010 1111 0000 1010 1010'), out, 0);
var expected = [
bin('011110 100001 010101 010101'),
bin('011110 100001 010101 010101')
];
assert.deepEqual(out, expected);
});
it('should expand with low 1', function() {
var out = [ 0, 0 ];
utils.expand(bin('1111 0000 1010 1010 1111 0000 1010 1011'), out, 0);
var expected = [
bin('111110 100001 010101 010101'),
bin('011110 100001 010101 010111')
];
assert.deepEqual(out, expected);
});
it('should expand with low 1', function() {
var out = [ 0, 0 ];
utils.expand(bin('10100010 01011100 00001011 11110100'), out, 0);
var expected = [
bin('010100 000100 001011 111000'),
bin('000001 010111 111110 101001')
];
assert.deepEqual(out, expected);
});
});
describe('substitute', function() {
it('should substitute', function() {
var input = [
bin('011000 010001 011110 111010'),
bin('100001 100110 010100 100111')
];
var output = utils.substitute(input[0], input[1]);
assert.equal(output, bin('0101 1100 1000 0010 1011 0101 1001 0111'));
});
});
describe('permute', function() {
it('should permute', function() {
var output = utils.permute(
bin('0101 1100 1000 0010 1011 0101 1001 0111'));
assert.equal(output, bin('0010 0011 0100 1010 1010 1001 1011 1011'));
});
});
});