aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/background/usecases/NavigateUseCase.test.ts82
-rw-r--r--test/content/presenters/NavigationPresenter.test.ts9
2 files changed, 82 insertions, 9 deletions
diff --git a/test/background/usecases/NavigateUseCase.test.ts b/test/background/usecases/NavigateUseCase.test.ts
new file mode 100644
index 0000000..13f3e99
--- /dev/null
+++ b/test/background/usecases/NavigateUseCase.test.ts
@@ -0,0 +1,82 @@
+import TabPresenter from '../../../src/background/presenters/TabPresenter';
+import NavigateUseCase from '../../../src/background/usecases/NavigateUseCase';
+import NavigateClient from '../../../src/background/clients/NavigateClient';
+// import { expect } from 'chai';
+import * as sinon from 'sinon';
+
+describe('NavigateUseCase', () => {
+ let sut: NavigateUseCase;
+ let tabPresenter: TabPresenter;
+ let navigateClient: NavigateClient;
+ beforeEach(() => {
+ tabPresenter = new TabPresenter();
+ navigateClient = new NavigateClient();
+ sut = new NavigateUseCase(tabPresenter, navigateClient);
+ });
+
+ describe('#openParent()', async () => {
+ it.only('opens parent directory of file', async() => {
+ var stub = sinon.stub(tabPresenter, 'getCurrent');
+ stub.returns(Promise.resolve({ url: 'https://google.com/fruits/yellow/banana' }))
+
+ var mock = sinon.mock(tabPresenter);
+ mock.expects('open').withArgs('https://google.com/fruits/yellow/');
+
+ await sut.openParent();
+
+ mock.verify();
+ });
+
+ it.only('opens parent directory of directory', async() => {
+ var stub = sinon.stub(tabPresenter, 'getCurrent');
+ stub.returns(Promise.resolve({ url: 'https://google.com/fruits/yellow/' }))
+
+ var mock = sinon.mock(tabPresenter);
+ mock.expects('open').withArgs('https://google.com/fruits/');
+
+ await sut.openParent();
+
+ mock.verify();
+ });
+
+ it.only('removes hash', async() => {
+ var stub = sinon.stub(tabPresenter, 'getCurrent');
+ stub.returns(Promise.resolve({ url: 'https://google.com/#top' }))
+
+ var mock = sinon.mock(tabPresenter);
+ mock.expects('open').withArgs('https://google.com/');
+
+ await sut.openParent();
+
+ mock.verify();
+ });
+
+ it.only('removes search query', async() => {
+ var stub = sinon.stub(tabPresenter, 'getCurrent');
+ stub.returns(Promise.resolve({ url: 'https://google.com/search?q=apple' }))
+
+ var mock = sinon.mock(tabPresenter);
+ mock.expects('open').withArgs('https://google.com/search');
+
+ await sut.openParent();
+
+ mock.verify();
+ });
+ });
+
+ describe('#openRoot()', () => {
+ it.only('opens root direectory', async() => {
+ var stub = sinon.stub(tabPresenter, 'getCurrent');
+ stub.returns(Promise.resolve({
+ url: 'https://google.com/seach?q=apple',
+ }))
+
+ var mock = sinon.mock(tabPresenter);
+ mock.expects('open').withArgs('https://google.com');
+
+ await sut.openRoot();
+
+ mock.verify();
+ });
+ });
+});
diff --git a/test/content/presenters/NavigationPresenter.test.ts b/test/content/presenters/NavigationPresenter.test.ts
index c1aca9a..5b6a8ca 100644
--- a/test/content/presenters/NavigationPresenter.test.ts
+++ b/test/content/presenters/NavigationPresenter.test.ts
@@ -132,13 +132,4 @@ describe('NavigationPresenter', () => {
'<a href="#dummy">next page</a><a rel="next" href="#next">click me</a>'
));
});
-
- describe('#parent', () => {
- // NOTE: not able to test location
- it('removes hash', () => {
- window.location.hash = '#section-1';
- sut.openParent();
- expect(document.location.hash).to.be.empty;
- });
- });
});