summaryrefslogtreecommitdiff
path: root/src/vm/instruction.test.js
diff options
context:
space:
mode:
authorsanine <sanine.not@pm.me>2023-05-23 10:08:35 -0500
committersanine <sanine.not@pm.me>2023-05-23 10:08:35 -0500
commit2880c1565102d8a969846c5e68300ced88066943 (patch)
tree8374eaf85ae2258f03e8f409f545e582e29ec439 /src/vm/instruction.test.js
parenta6a59d51f626426bb3257ad32ea86cec08d7e3b9 (diff)
implement SLT
Diffstat (limited to 'src/vm/instruction.test.js')
-rw-r--r--src/vm/instruction.test.js55
1 files changed, 54 insertions, 1 deletions
diff --git a/src/vm/instruction.test.js b/src/vm/instruction.test.js
index 63112fb..a93a3b0 100644
--- a/src/vm/instruction.test.js
+++ b/src/vm/instruction.test.js
@@ -1,7 +1,7 @@
'use strict';
const { Core } = require('./core.js');
-const { DAT, MOV, ADD, SUB, CMP } = require('./instruction.js');
+const { DAT, MOV, ADD, SUB, CMP, SLT } = require('./instruction.js');
const CORESIZE = 8000;
@@ -294,3 +294,56 @@ test('CMP properly compares B-field', () => {
expect(CMP(core, pc, ins)).toEqual([pc+2]);
});
+
+
+test('SLT properly compares full instructions', () => {
+ const core = new Core(CORESIZE);
+ const pc = 20;
+ core.data[pc] = {
+ opcode: 'SLT',
+ a: { mode: 'direct', value: 1 },
+ b: { mode: 'direct', value: 2 },
+ };
+ core.data[pc+1] = {
+ opcode: 'DAT',
+ a: { mode: 'immediate', value: 3 },
+ b: { mode: 'immediate', value: 4 },
+ };
+ core.data[pc+2] = {
+ opcode: 'DAT',
+ a: { mode: 'immediate', value: 3 },
+ b: { mode: 'immediate', value: 4 },
+ };
+ const ins = core.data[pc];
+
+ expect(SLT(core, pc, ins)).toEqual([pc+1]);
+
+ core.data[pc+2].b.value = 5;
+
+ expect(SLT(core, pc, ins)).toEqual([pc+2]);
+});
+
+
+
+test('SLT properly compares B-fields', () => {
+ const core = new Core(CORESIZE);
+ const pc = 20;
+ core.data[pc] = {
+ opcode: 'SLT',
+ a: { mode: 'immediate', value: 7 },
+ b: { mode: 'direct', value: 2 },
+ };
+ core.data[pc+2] = {
+ opcode: 'DAT',
+ a: { mode: 'immediate', value: 3 },
+ b: { mode: 'immediate', value: 4 },
+ };
+ const ins = core.data[pc];
+
+ expect(SLT(core, pc, ins)).toEqual([pc+1]);
+
+ core.data[pc+2].b.value = 8;
+
+ expect(SLT(core, pc, ins)).toEqual([pc+2]);
+});
+