add scripts to prevent family safety monitoring
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
import 'mocha';
|
||||
import { expect } from 'chai';
|
||||
import { ScriptCode } from '@/domain/ScriptCode';
|
||||
import { IScriptCode } from '../../../src/domain/IScriptCode';
|
||||
|
||||
describe('ScriptCode', () => {
|
||||
describe('scriptName', () => {
|
||||
@@ -15,75 +16,131 @@ describe('ScriptCode', () => {
|
||||
});
|
||||
});
|
||||
describe('code', () => {
|
||||
it('cannot construct with duplicate lines', () => {
|
||||
describe('throws with invalid code', () => {
|
||||
// arrange
|
||||
const code = 'duplicate\nduplicate\ntest\nduplicate';
|
||||
// act
|
||||
const act = () => createSut(code);
|
||||
// assert
|
||||
expect(act).to.throw();
|
||||
const scriptName = 'test-script';
|
||||
const testCases = [
|
||||
{
|
||||
name: 'throws when "execute" and "revert" are same',
|
||||
code: {
|
||||
execute: 'same',
|
||||
revert: 'same',
|
||||
},
|
||||
expectedError: `${scriptName} (revert): Code itself and its reverting code cannot be the same`,
|
||||
},
|
||||
{
|
||||
name: 'cannot construct with undefined "execute"',
|
||||
code: {
|
||||
execute: undefined,
|
||||
revert: 'code',
|
||||
},
|
||||
expectedError: `code of ${scriptName} is empty or undefined`,
|
||||
},
|
||||
{
|
||||
name: 'cannot construct with empty "execute"',
|
||||
code: {
|
||||
execute: '',
|
||||
revert: 'code',
|
||||
},
|
||||
expectedError: `code of ${scriptName} is empty or undefined`,
|
||||
},
|
||||
];
|
||||
for (const testCase of testCases) {
|
||||
it(testCase.name, () => {
|
||||
// act
|
||||
const act = () => new ScriptCode(scriptName, testCase.code.execute, testCase.code.revert);
|
||||
// assert
|
||||
expect(act).to.throw(testCase.expectedError);
|
||||
});
|
||||
}
|
||||
});
|
||||
it('cannot construct with empty lines', () => {
|
||||
describe('throws with invalid code in both "execute" or "revert"', () => {
|
||||
// arrange
|
||||
const code = 'line1\n\n\nline2';
|
||||
const scriptName = 'script-name';
|
||||
const testCases = [
|
||||
{
|
||||
testName: 'cannot construct with duplicate lines',
|
||||
code: 'duplicate\nduplicate\ntest\nduplicate',
|
||||
expectedMessage: 'Duplicates detected in script "$scriptName":\n duplicate\nduplicate',
|
||||
},
|
||||
{
|
||||
testName: 'cannot construct with empty lines',
|
||||
code: 'line1\n\n\nline2',
|
||||
expectedMessage: 'script has empty lines "$scriptName"',
|
||||
},
|
||||
];
|
||||
// act
|
||||
const act = () => createSut(code);
|
||||
const actions = [];
|
||||
for (const testCase of testCases) {
|
||||
const substituteScriptName = (name) => testCase.expectedMessage.replace('$scriptName', name);
|
||||
actions.push(...[
|
||||
{
|
||||
act: () => new ScriptCode(scriptName, testCase.code, undefined),
|
||||
testName: `execute: ${testCase.testName}`,
|
||||
expectedMessage: substituteScriptName(scriptName),
|
||||
},
|
||||
{
|
||||
act: () => new ScriptCode(scriptName, 'valid code', testCase.code),
|
||||
testName: `revert: ${testCase.testName}`,
|
||||
expectedMessage: substituteScriptName(`${scriptName} (revert)`),
|
||||
},
|
||||
]);
|
||||
}
|
||||
// assert
|
||||
expect(act).to.throw();
|
||||
for (const action of actions) {
|
||||
it(action.testName, () => {
|
||||
expect(action.act).to.throw(action.expectedMessage,
|
||||
`Code used: ${action.code}`);
|
||||
});
|
||||
}
|
||||
});
|
||||
it('cannot construct with empty or undefined values', () => {
|
||||
describe('sets as expected with valid "execute" or "revert"', () => {
|
||||
// arrange
|
||||
const name = 'test-code';
|
||||
const errorMessage = `code of ${name} is empty or undefined`;
|
||||
const invalidValues = [ '', undefined ];
|
||||
invalidValues.forEach((invalidValue) => {
|
||||
// act
|
||||
const act = () => new ScriptCode(name, invalidValue, '');
|
||||
// assert
|
||||
expect(act).to.throw(errorMessage);
|
||||
});
|
||||
});
|
||||
it('sets as expected', () => {
|
||||
// arrange
|
||||
const expected = 'expected-revert';
|
||||
const testCases = [
|
||||
{
|
||||
testName: 'code is a valid string',
|
||||
code: 'valid code',
|
||||
},
|
||||
{
|
||||
testName: 'code consists of frequent code parts',
|
||||
code: ') else (',
|
||||
},
|
||||
{
|
||||
testName: 'code is a frequent code part',
|
||||
code: ')',
|
||||
},
|
||||
{
|
||||
testName: 'code with duplicated comment lines (::)',
|
||||
code: ':: comment\n:: comment',
|
||||
},
|
||||
{
|
||||
testName: 'code with duplicated comment lines (REM)',
|
||||
code: 'REM comment\nREM comment',
|
||||
},
|
||||
];
|
||||
// act
|
||||
const sut = createSut(expected);
|
||||
const actions = [];
|
||||
for (const testCase of testCases) {
|
||||
actions.push(...[
|
||||
{
|
||||
testName: `execute: ${testCase.testName}`,
|
||||
act: () => createSut(testCase.code),
|
||||
expect: (sut: IScriptCode) => sut.execute === testCase.code,
|
||||
},
|
||||
{
|
||||
testName: `revert: ${testCase.testName}`,
|
||||
act: () => createSut('different code', testCase.code),
|
||||
expect: (sut: IScriptCode) => sut.revert === testCase.code,
|
||||
},
|
||||
]);
|
||||
}
|
||||
// assert
|
||||
expect(sut.execute).to.equal(expected);
|
||||
});
|
||||
});
|
||||
describe('revert', () => {
|
||||
it('cannot construct with duplicate lines', () => {
|
||||
// arrange
|
||||
const code = 'duplicate\nduplicate\ntest\nduplicate';
|
||||
// act
|
||||
const act = () => createSut('REM', code);
|
||||
// assert
|
||||
expect(act).to.throw();
|
||||
});
|
||||
it('cannot construct with empty lines', () => {
|
||||
// arrange
|
||||
const code = 'line1\n\n\nline2';
|
||||
// act
|
||||
const act = () => createSut('REM', code);
|
||||
// assert
|
||||
expect(act).to.throw();
|
||||
});
|
||||
it('cannot construct with when same as code', () => {
|
||||
// arrange
|
||||
const code = 'REM';
|
||||
// act
|
||||
const act = () => createSut(code, code);
|
||||
// assert
|
||||
expect(act).to.throw();
|
||||
});
|
||||
it('sets as expected', () => {
|
||||
// arrange
|
||||
const expected = 'expected-revert';
|
||||
// act
|
||||
const sut = createSut('abc', expected);
|
||||
// assert
|
||||
expect(sut.revert).to.equal(expected);
|
||||
for (const action of actions) {
|
||||
it(action.testName, () => {
|
||||
const sut = action.act();
|
||||
expect(action.expect(sut));
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user