UNPKG

filestack-js

Version:

Official JavaScript library for Filestack

246 lines (244 loc) 27.6 kB
/* * Copyright (c) 2018 by Filestack. * Some rights reserved. * * Licensed under the Apache License, Version 2.0 (the 'License'); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an 'AS IS' BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { __assign, __awaiter, __generator } from "tslib"; // import { config } from './../../config'; import nock from 'nock'; import { Prefetch } from './prefetch'; import { FsRequestErrorCode } from '../request'; var testApiKey = 'AHv2222222222444444uez'; var testSecurity = { policy: 'examplePolicy', signature: 'exampleSignature', }; var testURL = { fileApiUrl: '', uploadApiUrl: 'https://uploadtesturl-fs.com', cloudApiUrl: '', cdnUrl: '', pickerUrl: '', processUrl: '', }; var testSession = { apikey: testApiKey, urls: testURL, }; var scope = nock(testURL.uploadApiUrl); // mock cors responses for all request for browser tests scope.defaultReplyHeaders({ 'access-control-allow-origin': function (req) { var _a; return (_a = req.getHeader('origin')) === null || _a === void 0 ? void 0 : _a.toString(); }, 'access-control-allow-methods': function (req) { var _a; return (_a = req.getHeader('access-control-request-method')) === null || _a === void 0 ? void 0 : _a.toString(); }, 'access-control-allow-headers': function (req) { var _a; return (_a = req.getHeader('access-control-request-headers')) === null || _a === void 0 ? void 0 : _a.toString(); }, 'content-type': 'application/json', }); describe('Prefetch', function () { beforeEach(function () { scope .options(/.*/) .reply(204); }); it('should make correct request to prefetch and return new config', function () { return __awaiter(void 0, void 0, void 0, function () { var sessionCopy, serverResponse, test, prefetch, res; return __generator(this, function (_a) { switch (_a.label) { case 0: sessionCopy = __assign({}, testSession); serverResponse = { blocked: false, settings: { customsource: false, inapp_browser: false, }, permissions: { transforms_ui: false, }, updated_config: { fromSources: ['googledrive'], }, }; scope.post('/prefetch').once().reply(200, serverResponse); test = function () { return 2; }; prefetch = new Prefetch(sessionCopy); return [4 /*yield*/, prefetch.getConfig({ pickerOptions: { // @ts-ignore onFileSelected: test, fromSources: ['googledrive', 'test'], }, })]; case 1: res = _a.sent(); expect(res.pickerOptions.onFileSelected).toEqual(test); expect(res.pickerOptions.fromSources).toEqual(['googledrive']); scope.done(); return [2 /*return*/]; } }); }); }); it('should set correct params to sessions (prefetch)', function () { return __awaiter(void 0, void 0, void 0, function () { var sessionCopy, serverResponse, prefetch, res; return __generator(this, function (_a) { switch (_a.label) { case 0: sessionCopy = __assign({}, testSession); serverResponse = { blocked: false, settings: { customsource: false, inapp_browser: true, }, permissions: { transforms_ui: true, }, updated_config: { fromSources: ['googledrive'], }, }; scope.post('/prefetch').once().reply(200, serverResponse); prefetch = new Prefetch(sessionCopy); return [4 /*yield*/, prefetch.getConfig({ pickerOptions: { fromSources: ['facebook', 'test'], }, })]; case 1: res = _a.sent(); expect(sessionCopy.prefetch).toEqual(expect.any(Object)); expect(sessionCopy.prefetch.settings.inapp_browser).toEqual(true); expect(sessionCopy.prefetch.permissions.transforms_ui).toEqual(true); scope.done(); return [2 /*return*/]; } }); }); }); it('should throw error when response code is other thant 200', function () { return __awaiter(void 0, void 0, void 0, function () { var sessionCopy, prefetch, err_1; return __generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 2, , 3]); sessionCopy = __assign({}, testSession); prefetch = new Prefetch(sessionCopy); scope.post('/prefetch').once().reply(500); return [4 /*yield*/, prefetch.getConfig({})]; case 1: _a.sent(); return [3 /*break*/, 3]; case 2: err_1 = _a.sent(); expect(err_1.code).toEqual(FsRequestErrorCode.SERVER); return [3 /*break*/, 3]; case 3: scope.done(); return [2 /*return*/]; } }); }); }); it('should add security to request when provided', function () { return __awaiter(void 0, void 0, void 0, function () { var sessionCopy, mockPref, prefetch, res; return __generator(this, function (_a) { switch (_a.label) { case 0: sessionCopy = __assign(__assign({}, testSession), { signature: testSecurity.signature, policy: testSecurity.policy }); mockPref = jest.fn().mockImplementation(function () { return ({}); }); scope.post('/prefetch').once().reply(200, function (_, data) { return mockPref(data); }); prefetch = new Prefetch(sessionCopy); return [4 /*yield*/, prefetch.getConfig({ pickerOptions: {}, })]; case 1: res = _a.sent(); expect(mockPref).toHaveBeenCalledWith({ apikey: testApiKey, settings: ['inapp_browser'], security: { signature: testSecurity.signature, policy: testSecurity.policy, }, }); scope.done(); return [2 /*return*/]; } }); }); }); it('should always add inapp browser setting to request', function () { return __awaiter(void 0, void 0, void 0, function () { var mockPref, prefetch; return __generator(this, function (_a) { switch (_a.label) { case 0: mockPref = jest.fn().mockImplementation(function () { return ({}); }); scope.post('/prefetch').once().reply(200, function (_, data) { return mockPref(data); }); prefetch = new Prefetch(__assign({}, testSession)); return [4 /*yield*/, prefetch.getConfig({})]; case 1: _a.sent(); expect(mockPref).toHaveBeenCalledWith({ apikey: testApiKey, settings: ['inapp_browser'], }); scope.done(); return [2 /*return*/]; } }); }); }); it('should always add inapp browser setting to request event if some settings are provided', function () { return __awaiter(void 0, void 0, void 0, function () { var mockPref, prefetch; return __generator(this, function (_a) { switch (_a.label) { case 0: mockPref = jest.fn().mockImplementation(function () { return ({}); }); scope.post('/prefetch').once().reply(200, function (_, data) { return mockPref(data); }); prefetch = new Prefetch(__assign({}, testSession)); return [4 /*yield*/, prefetch.getConfig({ settings: ['inapp_browser'] })]; case 1: _a.sent(); expect(mockPref).toHaveBeenCalledWith({ apikey: testApiKey, settings: ['inapp_browser'], }); scope.done(); return [2 /*return*/]; } }); }); }); it('should return old config when updated_config is missing in response', function () { return __awaiter(void 0, void 0, void 0, function () { var sessionCopy, pickerOptions, prefetch, res; return __generator(this, function (_a) { switch (_a.label) { case 0: sessionCopy = __assign(__assign({}, testSession), { signature: testSecurity.signature, policy: testSecurity.policy }); scope.post('/prefetch').once().reply(200, { blocked: true, }); pickerOptions = { uploadInBackground: true, onUploadDone: function () { return console.log; }, storeTo: { location: 'asd', }, }; prefetch = new Prefetch(sessionCopy); return [4 /*yield*/, prefetch.getConfig({ pickerOptions: pickerOptions })]; case 1: res = _a.sent(); expect(res.pickerOptions).toEqual(pickerOptions); scope.done(); return [2 /*return*/]; } }); }); }); }); //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/api/prefetch.spec.browser.ts"],"names":[],"mappings":"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","file":"lib/api/prefetch.spec.browser.js","sourcesContent":["/*\n * Copyright (c) 2018 by Filestack.\n * Some rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the 'License');\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an 'AS IS' BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// import { config } from './../../config';\nimport nock from 'nock';\nimport { Prefetch, PrefetchEvents } from './prefetch';\nimport { Session, Security } from './../client';\nimport { FsRequestErrorCode } from '../request';\n\nconst testApiKey = 'AHv2222222222444444uez';\nconst testSecurity: Security = {\n  policy: 'examplePolicy',\n  signature: 'exampleSignature',\n};\n\nconst testURL = {\n  fileApiUrl: '',\n  uploadApiUrl: 'https://uploadtesturl-fs.com',\n  cloudApiUrl: '',\n  cdnUrl: '',\n  pickerUrl: '',\n  processUrl: '',\n};\n\nconst testSession: Session = {\n  apikey: testApiKey,\n  urls: testURL,\n};\n\nlet scope = nock(testURL.uploadApiUrl);\n\n// mock cors responses for all request for browser tests\nscope.defaultReplyHeaders({\n  'access-control-allow-origin': function (req) { return req.getHeader('origin')?.toString(); },\n  'access-control-allow-methods': function (req) { return req.getHeader('access-control-request-method')?.toString(); },\n  'access-control-allow-headers': function (req) { return req.getHeader('access-control-request-headers')?.toString(); },\n  'content-type': 'application/json',\n});\n\ndescribe('Prefetch', () => {\n  beforeEach(() => {\n    scope\n    .options(/.*/)\n    .reply(204);\n  });\n\n  it('should make correct request to prefetch and return new config', async () => {\n    const sessionCopy =  { ...testSession };\n\n    const serverResponse = {\n      blocked: false,\n      settings: {\n        customsource: false,\n        inapp_browser: false,\n      },\n      permissions: {\n        transforms_ui: false,\n      },\n      updated_config: {\n        fromSources: ['googledrive'],\n      },\n    };\n\n    scope.post('/prefetch').once().reply(200, serverResponse);\n\n    const test = () => 2;\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({\n      pickerOptions: {\n        // @ts-ignore\n        onFileSelected: test,\n        fromSources: ['googledrive', 'test'],\n      },\n    });\n\n    expect(res.pickerOptions.onFileSelected).toEqual(test);\n    expect(res.pickerOptions.fromSources).toEqual(['googledrive']);\n\n    scope.done();\n  });\n\n  it('should set correct params to sessions (prefetch)', async () => {\n    const sessionCopy =  { ...testSession };\n    const serverResponse = {\n      blocked: false,\n      settings: {\n        customsource: false,\n        inapp_browser: true,\n      },\n      permissions: {\n        transforms_ui: true,\n      },\n      updated_config: {\n        fromSources: ['googledrive'],\n      },\n    };\n\n    scope.post('/prefetch').once().reply(200, serverResponse);\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({\n      pickerOptions: {\n        fromSources: ['facebook', 'test'],\n      },\n    });\n\n    expect(sessionCopy.prefetch).toEqual(expect.any(Object));\n    expect(sessionCopy.prefetch.settings.inapp_browser).toEqual(true);\n    expect(sessionCopy.prefetch.permissions.transforms_ui).toEqual(true);\n\n    scope.done();\n  });\n\n  it('should throw error when response code is other thant 200', async () => {\n    try {\n      const sessionCopy =  { ...testSession };\n      const prefetch = new Prefetch(sessionCopy);\n\n      scope.post('/prefetch').once().reply(500);\n\n      await prefetch.getConfig({});\n    } catch (err) {\n      expect(err.code).toEqual(FsRequestErrorCode.SERVER);\n    }\n\n    scope.done();\n  });\n\n  it('should add security to request when provided', async () => {\n    const sessionCopy =  {\n      ...testSession,\n      signature: testSecurity.signature,\n      policy: testSecurity.policy,\n    };\n\n    const mockPref = jest.fn() .mockImplementation(() => ({}));\n\n    scope.post('/prefetch').once().reply(200, (_, data) => mockPref(data));\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({\n      pickerOptions: {},\n    });\n\n    expect(mockPref).toHaveBeenCalledWith({\n      apikey: testApiKey,\n      settings: ['inapp_browser'],\n      security: {\n        signature: testSecurity.signature,\n        policy: testSecurity.policy,\n      },\n    });\n\n    scope.done();\n  });\n\n  it('should always add inapp browser setting to request', async () => {\n    const mockPref = jest.fn() .mockImplementation(() => ({}));\n    scope.post('/prefetch').once().reply(200, (_, data) => mockPref(data));\n\n    const prefetch = new Prefetch({ ...testSession });\n    await prefetch.getConfig({});\n\n    expect(mockPref).toHaveBeenCalledWith({\n      apikey: testApiKey,\n      settings: ['inapp_browser'],\n    });\n\n    scope.done();\n  });\n\n  it('should always add inapp browser setting to request event if some settings are provided', async () => {\n    const mockPref = jest.fn() .mockImplementation(() => ({}));\n    scope.post('/prefetch').once().reply(200, (_, data) => mockPref(data));\n\n    const prefetch = new Prefetch({ ...testSession });\n    await prefetch.getConfig({ settings: ['inapp_browser'] });\n\n    expect(mockPref).toHaveBeenCalledWith({\n      apikey: testApiKey,\n      settings: ['inapp_browser'],\n    });\n\n    scope.done();\n  });\n\n  it('should return old config when updated_config is missing in response', async () => {\n    const sessionCopy =  {\n      ...testSession,\n      signature: testSecurity.signature,\n      policy: testSecurity.policy,\n    };\n\n    scope.post('/prefetch').once().reply(200, {\n      blocked: true,\n    });\n\n    const pickerOptions = {\n      uploadInBackground: true,\n      onUploadDone: () => console.log,\n      storeTo: {\n        location: 'asd',\n      },\n    };\n\n    const prefetch = new Prefetch(sessionCopy);\n    const res = await prefetch.getConfig({ pickerOptions });\n\n    expect(res.pickerOptions).toEqual(pickerOptions);\n\n    scope.done();\n  });\n});\n"]}