Skip to content

Commit ab4f70b

Browse files
committed
Adding tests for "Genome sequencing".
1 parent cfb6628 commit ab4f70b

File tree

10 files changed

+137
-0
lines changed

10 files changed

+137
-0
lines changed

CHANGELOG.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
99
- Tests for "Blunder - episode 2".
1010
- Tests for "Blunder - episode 3".
1111
- Tests for "CGX formatter".
12+
- Tests for "Genome sequencing".
1213

1314
## [1.3.0] - 2022-03-02
1415
### Added
Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
/**
2+
* The "Genome sequencing" puzzle.
3+
*/
4+
function execute(readline) {
5+
const N = parseInt(readline());
6+
for (let i = 0; i < N; i++) {
7+
const subseq = readline();
8+
}
9+
10+
// Write an answer using console.log()
11+
// To debug: console.error('Debug messages...');
12+
13+
console.log('answer');
14+
}
15+
16+
export { execute };
Lines changed: 97 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,97 @@
1+
import { assert } from 'chai';
2+
import sinon from 'sinon';
3+
import File from '../../../File.js';
4+
import { execute } from '../../../../lib/training/hard/genomeSequencing/genomeSequencing.js';
5+
6+
/**
7+
* Tests for the "Genome sequencing" puzzle.
8+
*/
9+
suite('Genome sequencing', function() {
10+
const sandbox = sinon.createSandbox();
11+
12+
setup(function () {
13+
sandbox.stub(console, "log");
14+
});
15+
16+
teardown(function () {
17+
sandbox.restore();
18+
});
19+
20+
21+
test('AACCTT', function() {
22+
let inputFile = new File('./test/training/hard/genomeSequencing/input/01 - AACCTT.txt');
23+
24+
execute(inputFile.readline.bind(inputFile));
25+
26+
assert.strictEqual(
27+
console.log.getCall(0).args[0],
28+
6
29+
);
30+
});
31+
32+
test('AGATTACAGA', function() {
33+
let inputFile = new File('./test/training/hard/genomeSequencing/input/02 - AGATTACAGA.txt');
34+
35+
execute(inputFile.readline.bind(inputFile));
36+
37+
assert.strictEqual(
38+
console.log.getCall(0).args[0],
39+
10
40+
);
41+
});
42+
43+
test('AACTT', function() {
44+
let inputFile = new File('./test/training/hard/genomeSequencing/input/03 - AACTT.txt');
45+
46+
execute(inputFile.readline.bind(inputFile));
47+
48+
assert.strictEqual(
49+
console.log.getCall(0).args[0],
50+
5
51+
);
52+
});
53+
54+
test('AGATTA', function() {
55+
let inputFile = new File('./test/training/hard/genomeSequencing/input/04 - AGATTA.txt');
56+
57+
execute(inputFile.readline.bind(inputFile));
58+
59+
assert.strictEqual(
60+
console.log.getCall(0).args[0],
61+
6
62+
);
63+
});
64+
65+
test('reversed AGATTA', function() {
66+
let inputFile = new File('./test/training/hard/genomeSequencing/input/05 - reversed AGATTA.txt');
67+
68+
execute(inputFile.readline.bind(inputFile));
69+
70+
assert.strictEqual(
71+
console.log.getCall(0).args[0],
72+
6
73+
);
74+
});
75+
76+
test('ATCG', function() {
77+
let inputFile = new File('./test/training/hard/genomeSequencing/input/06 - ATCG.txt');
78+
79+
execute(inputFile.readline.bind(inputFile));
80+
81+
assert.strictEqual(
82+
console.log.getCall(0).args[0],
83+
4
84+
);
85+
});
86+
87+
test('CCCTGACATGA', function() {
88+
let inputFile = new File('./test/training/hard/genomeSequencing/input/07 - CCCTGACATGA.txt');
89+
90+
execute(inputFile.readline.bind(inputFile));
91+
92+
assert.strictEqual(
93+
console.log.getCall(0).args[0],
94+
11
95+
);
96+
});
97+
});
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
2
2+
AAC
3+
CCTT
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
2
2+
AAC
3+
CCTT
Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
3
2+
TT
3+
AA
4+
ACT
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
2
2+
AGATTA
3+
GAT
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
2
2+
GAT
3+
AGATTA
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
2
2+
AT
3+
CG
Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
3
2+
CCCTG
3+
TGACA
4+
CATGA

0 commit comments

Comments
 (0)