Make addon-enabled as a clean architecture
This commit is contained in:
parent
05ef6a8ca3
commit
e76ca380f7
16 changed files with 218 additions and 96 deletions
|
@ -1,17 +0,0 @@
|
|||
import * as actions from 'content/actions';
|
||||
import addonReducer from 'content/reducers/addon';
|
||||
|
||||
describe("addon reducer", () => {
|
||||
it('return the initial state', () => {
|
||||
let state = addonReducer(undefined, {});
|
||||
expect(state).to.have.property('enabled', true);
|
||||
});
|
||||
|
||||
it('return next state for ADDON_SET_ENABLED', () => {
|
||||
let action = { type: actions.ADDON_SET_ENABLED, enabled: true };
|
||||
let prev = { enabled: false };
|
||||
let state = addonReducer(prev, action);
|
||||
|
||||
expect(state.enabled).is.equal(true);
|
||||
});
|
||||
});
|
15
test/content/repositories/AddonEnabledRepository.test.ts
Normal file
15
test/content/repositories/AddonEnabledRepository.test.ts
Normal file
|
@ -0,0 +1,15 @@
|
|||
import { AddonEnabledRepositoryImpl } from '../../../src/content/repositories/AddonEnabledRepository';
|
||||
import { expect } from 'chai';
|
||||
|
||||
describe('AddonEnabledRepositoryImpl', () => {
|
||||
it('updates and gets current value', () => {
|
||||
let sut = new AddonEnabledRepositoryImpl();
|
||||
|
||||
sut.set(true);
|
||||
expect(sut.get()).to.be.true;
|
||||
|
||||
sut.set(false);
|
||||
expect(sut.get()).to.be.false;
|
||||
});
|
||||
});
|
||||
|
90
test/content/usecases/AddonEnabledUseCase.test.ts
Normal file
90
test/content/usecases/AddonEnabledUseCase.test.ts
Normal file
|
@ -0,0 +1,90 @@
|
|||
import AddonEnabledRepository from '../../../src/content/repositories/AddonEnabledRepository';
|
||||
import AddonEnabledUseCase from '../../../src/content/usecases/AddonEnabledUseCase';
|
||||
import AddonIndicatorClient from '../../../src/content/client/AddonIndicatorClient';
|
||||
import { expect } from 'chai';
|
||||
|
||||
class MockAddonEnabledRepository implements AddonEnabledRepository {
|
||||
private enabled: boolean;
|
||||
|
||||
constructor(init: boolean) {
|
||||
this.enabled = init;
|
||||
}
|
||||
|
||||
set(on: boolean): void {
|
||||
this.enabled = on;
|
||||
}
|
||||
|
||||
get(): boolean {
|
||||
return this.enabled;
|
||||
}
|
||||
}
|
||||
|
||||
class MockAddonIndicatorClient implements AddonIndicatorClient {
|
||||
public enabled: boolean;
|
||||
|
||||
constructor(init: boolean) {
|
||||
this.enabled = init;
|
||||
}
|
||||
|
||||
async setEnabled(enabled: boolean): Promise<void> {
|
||||
this.enabled = enabled;
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
describe('AddonEnabledUseCase', () => {
|
||||
let repository: MockAddonEnabledRepository;
|
||||
let indicator: MockAddonIndicatorClient;
|
||||
let sut: AddonEnabledUseCase;
|
||||
|
||||
beforeEach(() => {
|
||||
repository = new MockAddonEnabledRepository(true);
|
||||
indicator = new MockAddonIndicatorClient(false);
|
||||
sut = new AddonEnabledUseCase({ repository, indicator });
|
||||
});
|
||||
|
||||
describe('#enable', () => {
|
||||
it('store and indicate as enabled', async() => {
|
||||
await sut.enable();
|
||||
|
||||
expect(repository.get()).to.be.true;
|
||||
expect(indicator.enabled).to.be.true;
|
||||
});
|
||||
});
|
||||
|
||||
describe('#disable', async() => {
|
||||
it('store and indicate as disabled', async() => {
|
||||
await sut.disable();
|
||||
|
||||
expect(repository.get()).to.be.false;
|
||||
expect(indicator.enabled).to.be.false;
|
||||
});
|
||||
});
|
||||
|
||||
describe('#toggle', () => {
|
||||
it('toggled enabled and disabled', async() => {
|
||||
repository.set(true);
|
||||
await sut.toggle();
|
||||
|
||||
expect(repository.get()).to.be.false;
|
||||
expect(indicator.enabled).to.be.false;
|
||||
|
||||
repository.set(false);
|
||||
|
||||
await sut.toggle();
|
||||
|
||||
expect(repository.get()).to.be.true;
|
||||
expect(indicator.enabled).to.be.true;
|
||||
});
|
||||
});
|
||||
|
||||
describe('#getEnabled', () => {
|
||||
it('returns current addon enabled', () => {
|
||||
repository.set(true);
|
||||
expect(sut.getEnabled()).to.be.true;
|
||||
|
||||
repository.set(false);
|
||||
expect(sut.getEnabled()).to.be.false;
|
||||
});
|
||||
});
|
||||
});
|
Reference in a new issue