X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/2c4b5777c5bea7b862e481038566e93194b06aa9..8297f0f273e326e64145a48266805b0b3d073c32:/src/common/webdav.test.ts diff --git a/src/common/webdav.test.ts b/src/common/webdav.test.ts index 63771688..b928f82a 100644 --- a/src/common/webdav.test.ts +++ b/src/common/webdav.test.ts @@ -7,7 +7,20 @@ import { WebDAV } from "./webdav"; describe('WebDAV', () => { it('makes use of provided config', async () => { const { open, load, setRequestHeader, createRequest } = mockCreateRequest(); - const webdav = WebDAV.create({ baseUrl: 'http://foo.com/', headers: { Authorization: 'Basic' } }, createRequest); + const webdav = new WebDAV({ baseURL: 'http://foo.com/', headers: { Authorization: 'Basic' } }, createRequest); + const promise = webdav.propfind('foo'); + load(); + const request = await promise; + expect(open).toHaveBeenCalledWith('PROPFIND', 'http://foo.com/foo'); + expect(setRequestHeader).toHaveBeenCalledWith('Authorization', 'Basic'); + expect(request).toBeInstanceOf(XMLHttpRequest); + }); + + it('allows to modify defaults after instantiation', async () => { + const { open, load, setRequestHeader, createRequest } = mockCreateRequest(); + const webdav = new WebDAV(undefined, createRequest); + webdav.defaults.baseURL = 'http://foo.com/'; + webdav.defaults.headers = { Authorization: 'Basic' }; const promise = webdav.propfind('foo'); load(); const request = await promise; @@ -18,7 +31,7 @@ describe('WebDAV', () => { it('PROPFIND', async () => { const { open, load, createRequest } = mockCreateRequest(); - const webdav = WebDAV.create(undefined, createRequest); + const webdav = new WebDAV(undefined, createRequest); const promise = webdav.propfind('foo'); load(); const request = await promise; @@ -28,22 +41,20 @@ describe('WebDAV', () => { it('PUT', async () => { const { open, send, load, progress, createRequest } = mockCreateRequest(); - const onProgress = jest.fn(); - const webdav = WebDAV.create(undefined, createRequest); - const promise = webdav.put('foo', { data: 'Test data', onProgress }); + const webdav = new WebDAV(undefined, createRequest); + const promise = webdav.put('foo', 'Test data'); progress(); load(); const request = await promise; expect(open).toHaveBeenCalledWith('PUT', 'foo'); expect(send).toHaveBeenCalledWith('Test data'); - expect(onProgress).toHaveBeenCalled(); expect(request).toBeInstanceOf(XMLHttpRequest); }); it('COPY', async () => { const { open, setRequestHeader, load, createRequest } = mockCreateRequest(); - const webdav = WebDAV.create(undefined, createRequest); - const promise = webdav.copy('foo', { destination: 'foo-copy' }); + const webdav = new WebDAV(undefined, createRequest); + const promise = webdav.copy('foo', 'foo-copy'); load(); const request = await promise; expect(open).toHaveBeenCalledWith('COPY', 'foo'); @@ -51,20 +62,68 @@ describe('WebDAV', () => { expect(request).toBeInstanceOf(XMLHttpRequest); }); + it('COPY - adds baseURL with trailing slash to Destination header', async () => { + const { open, setRequestHeader, load, createRequest } = mockCreateRequest(); + const webdav = new WebDAV(undefined, createRequest); + webdav.defaults.baseURL = 'base/'; + const promise = webdav.copy('foo', 'foo-copy'); + load(); + const request = await promise; + expect(open).toHaveBeenCalledWith('COPY', 'base/foo'); + expect(setRequestHeader).toHaveBeenCalledWith('Destination', 'base/foo-copy'); + expect(request).toBeInstanceOf(XMLHttpRequest); + }); + + it('COPY - adds baseURL without trailing slash to Destination header', async () => { + const { open, setRequestHeader, load, createRequest } = mockCreateRequest(); + const webdav = new WebDAV(undefined, createRequest); + webdav.defaults.baseURL = 'base'; + const promise = webdav.copy('foo', 'foo-copy'); + load(); + const request = await promise; + expect(open).toHaveBeenCalledWith('COPY', 'base/foo'); + expect(setRequestHeader).toHaveBeenCalledWith('Destination', 'base/foo-copy'); + expect(request).toBeInstanceOf(XMLHttpRequest); + }); + it('MOVE', async () => { const { open, setRequestHeader, load, createRequest } = mockCreateRequest(); - const webdav = WebDAV.create(undefined, createRequest); - const promise = webdav.move('foo', { destination: 'foo-copy' }); + const webdav = new WebDAV(undefined, createRequest); + const promise = webdav.move('foo', 'foo-moved'); load(); const request = await promise; expect(open).toHaveBeenCalledWith('MOVE', 'foo'); - expect(setRequestHeader).toHaveBeenCalledWith('Destination', 'foo-copy'); + expect(setRequestHeader).toHaveBeenCalledWith('Destination', 'foo-moved'); + expect(request).toBeInstanceOf(XMLHttpRequest); + }); + + it('MOVE - adds baseURL with trailing slash to Destination header', async () => { + const { open, setRequestHeader, load, createRequest } = mockCreateRequest(); + const webdav = new WebDAV(undefined, createRequest); + webdav.defaults.baseURL = 'base/'; + const promise = webdav.move('foo', 'foo-moved'); + load(); + const request = await promise; + expect(open).toHaveBeenCalledWith('MOVE', 'base/foo'); + expect(setRequestHeader).toHaveBeenCalledWith('Destination', 'base/foo-moved'); + expect(request).toBeInstanceOf(XMLHttpRequest); + }); + + it('MOVE - adds baseURL without trailing slash to Destination header', async () => { + const { open, setRequestHeader, load, createRequest } = mockCreateRequest(); + const webdav = new WebDAV(undefined, createRequest); + webdav.defaults.baseURL = 'base'; + const promise = webdav.move('foo', 'foo-moved'); + load(); + const request = await promise; + expect(open).toHaveBeenCalledWith('MOVE', 'base/foo'); + expect(setRequestHeader).toHaveBeenCalledWith('Destination', 'base/foo-moved'); expect(request).toBeInstanceOf(XMLHttpRequest); }); it('DELETE', async () => { const { open, load, createRequest } = mockCreateRequest(); - const webdav = WebDAV.create(undefined, createRequest); + const webdav = new WebDAV(undefined, createRequest); const promise = webdav.delete('foo'); load(); const request = await promise;