UNPKG

filestack-js

Version:

Official JavaScript library for Filestack

103 lines (101 loc) 14.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 { preview, getUrl } from './preview'; import { config } from './../../config'; var mockAppendChild = jest.fn(); var defaultSession = { apikey: 'TEST_API_KEY', urls: Object.assign({}, config.urls), }; describe('api:upload:preview', function () { beforeEach(function () { jest.spyOn(window, 'open').mockImplementation(); var createdElement = { src: '', width: '', height: '', }; jest.spyOn(document, 'createElement').mockReturnValue(createdElement); jest.spyOn(document, 'getElementById').mockImplementation(function (id) { var obj; if (id === 'testId') { obj = { appendChild: mockAppendChild }; } return obj; }); }); describe('preview', function () { it('should open a proper url with preview of a file', function () { var handle = 'testHandle'; preview(defaultSession, handle); expect(window.open).toBeCalledTimes(1); expect(window.open).toBeCalledWith('https://cdn.filestackcontent.com/preview/testHandle', 'testHandle'); }); it('should open a proper url with preview of a file with src handle', function () { var handle = 'src://test123/test.jpg'; preview(defaultSession, handle); expect(window.open).toBeCalledTimes(1); expect(window.open).toBeCalledWith('https://cdn.filestackcontent.com/TEST_API_KEY/preview/src://test123/test.jpg', 'src://test123/test.jpg'); }); it('should open iframe inside provided options.id', function () { var handle = 'src://test123/test.jpg'; var options = { id: 'testId', css: 'customCss', }; preview(defaultSession, handle, options); var expected = { 'height': '100%', 'width': '100%', 'src': 'https://cdn.filestackcontent.com/TEST_API_KEY/preview=css:%22customCss%22/src://test123/test.jpg' }; expect(mockAppendChild).toBeCalledTimes(1); expect(mockAppendChild).toBeCalledWith(expected); }); it('should throw an error when handle is not provided', function () { expect(function () { preview(defaultSession); }).toThrow('A valid Filestack handle or storage alias is required for preview'); }); it('should throw an error when id provided and dom element not found', function () { var handle = 'src://test123/test.jpg'; var options = { id: 'testId2', }; expect(function () { preview(defaultSession, handle, options); }).toThrow('DOM Element with id "testId2" not found.'); }); it('should throw an error on invalid preview params', function () { var handle = 'src://test123/test.jpg'; var options = { id: {}, test: 123, }; // @ts-ignore expect(function () { preview(defaultSession, handle, options); }).toThrow('Invalid preview params'); }); }); describe('getUrl', function () { it('should be able to get url with security', function () { var handle = 'TEST_HANDLE'; var options = { id: 'testId2', }; var security = { policy: 'eyJleHBpcnkiOjE1MjM1OTU2MDAsImNhbGwiOlsicmVhZCIsImNvbnZlcnQiXSwiaGFuZGxlIjoiYmZUTkNpZ1JMcTBRTU9yc0ZLemIifQ==', signature: 'ab1624c9f219ca0118f1af43d21ee87a09a07645c15c9fdbb7447818739c2b8b', }; var result = getUrl(defaultSession, handle, options, security); var expected = 'https://cdn.filestackcontent.com/preview/security=policy:eyJleHBpcnkiOjE1MjM1OTU2MDAsImNhbGwiOlsicmVhZCIsImNvbnZlcnQiXSwiaGFuZGxlIjoiYmZUTkNpZ1JMcTBRTU9yc0ZLemIifQ==,signature:ab1624c9f219ca0118f1af43d21ee87a09a07645c15c9fdbb7447818739c2b8b/TEST_HANDLE'; expect(result).toBe(expected); }); }); }); //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/api/preview.spec.browser.ts"],"names":[],"mappings":"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","file":"lib/api/preview.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\nimport { preview, getUrl } from './preview';\nimport { config } from './../../config';\n\nconst mockAppendChild = jest.fn();\n\nconst defaultSession = {\n  apikey: 'TEST_API_KEY',\n  urls: Object.assign({}, config.urls),\n};\n\ndescribe('api:upload:preview', () => {\n  beforeEach(() => {\n    jest.spyOn(window, 'open').mockImplementation();\n\n    const createdElement: any = {\n      src: '',\n      width: '',\n      height: '',\n    };\n    jest.spyOn(document, 'createElement').mockReturnValue(createdElement);\n\n    jest.spyOn(document, 'getElementById').mockImplementation((id) => {\n      let obj;\n\n      if (id === 'testId') {\n        obj = { appendChild: mockAppendChild };\n      }\n\n      return obj;\n    });\n  });\n\n  describe('preview', () => {\n    it('should open a proper url with preview of a file', () => {\n      const handle = 'testHandle';\n      preview(defaultSession, handle);\n      expect(window.open).toBeCalledTimes(1);\n      expect(window.open).toBeCalledWith('https://cdn.filestackcontent.com/preview/testHandle', 'testHandle');\n    });\n\n    it('should open a proper url with preview of a file with src handle', () => {\n      const handle = 'src://test123/test.jpg';\n      preview(defaultSession, handle);\n\n      expect(window.open).toBeCalledTimes(1);\n      expect(window.open).toBeCalledWith('https://cdn.filestackcontent.com/TEST_API_KEY/preview/src://test123/test.jpg', 'src://test123/test.jpg');\n    });\n\n    it('should open iframe inside provided options.id', () => {\n      const handle = 'src://test123/test.jpg';\n      const options = {\n        id: 'testId',\n        css: 'customCss',\n      };\n\n      preview(defaultSession, handle, options);\n      const expected = { 'height': '100%', 'width': '100%', 'src': 'https://cdn.filestackcontent.com/TEST_API_KEY/preview=css:%22customCss%22/src://test123/test.jpg' };\n      expect(mockAppendChild).toBeCalledTimes(1);\n      expect(mockAppendChild).toBeCalledWith(expected);\n    });\n\n    it('should throw an error when handle is not provided', () => {\n      expect(() => { preview(defaultSession); }).toThrow('A valid Filestack handle or storage alias is required for preview');\n    });\n\n    it('should throw an error when id provided and dom element not found', () => {\n      const handle = 'src://test123/test.jpg';\n      const options = {\n        id: 'testId2',\n      };\n      expect(() => { preview(defaultSession, handle, options); }).toThrow('DOM Element with id \"testId2\" not found.');\n    });\n\n    it('should throw an error on invalid preview params', () => {\n      const handle = 'src://test123/test.jpg';\n      const options = {\n        id: {},\n        test: 123,\n      };\n      // @ts-ignore\n      expect(() => { preview(defaultSession, handle, options); }).toThrow('Invalid preview params');\n    });\n  });\n\n  describe('getUrl', () => {\n    it('should be able to get url with security', () => {\n      const handle = 'TEST_HANDLE';\n      const options = {\n        id: 'testId2',\n      };\n\n      const security = {\n        policy: 'eyJleHBpcnkiOjE1MjM1OTU2MDAsImNhbGwiOlsicmVhZCIsImNvbnZlcnQiXSwiaGFuZGxlIjoiYmZUTkNpZ1JMcTBRTU9yc0ZLemIifQ==',\n        signature: 'ab1624c9f219ca0118f1af43d21ee87a09a07645c15c9fdbb7447818739c2b8b',\n      };\n\n      const result = getUrl(defaultSession, handle, options, security);\n      const expected = 'https://cdn.filestackcontent.com/preview/security=policy:eyJleHBpcnkiOjE1MjM1OTU2MDAsImNhbGwiOlsicmVhZCIsImNvbnZlcnQiXSwiaGFuZGxlIjoiYmZUTkNpZ1JMcTBRTU9yc0ZLemIifQ==,signature:ab1624c9f219ca0118f1af43d21ee87a09a07645c15c9fdbb7447818739c2b8b/TEST_HANDLE';\n      expect(result).toBe(expected);\n    });\n  });\n});\n"]}