Make addon-enabled as a clean architecture

This commit is contained in:
Shin'ya Ueoka 2019-05-10 22:27:20 +09:00
parent 05ef6a8ca3
commit e76ca380f7
16 changed files with 218 additions and 96 deletions

View file

@ -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);
});
});

View 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;
});
});

View 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;
});
});
});