filestack-js
Version:
Official JavaScript library for Filestack
187 lines (185 loc) • 20.5 kB
JavaScript
/*
* 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 { __awaiter, __generator } from "tslib";
import { storeURL } from './store';
import { FilestackError } from './../../filestack_error';
import { config } from './../../config';
import { FsRequest } from './../request';
import { Filelink } from './../filelink';
jest.mock('./../filelink');
jest.mock('./../request');
var mockedSession = {
apikey: 'fakeApikey',
urls: config.urls,
};
var workflowIds = ['123', '321'];
var storeTaskDef = [{ name: 'store', params: {} }];
var storeTaskDefWithWorkflows = [{ name: 'store', params: {} }];
var sourceToStore = 'urlToStore';
describe('StoreURL', function () {
beforeEach(function () {
// @ts-ignore
FsRequest.post.mockImplementation(function (_, options) {
var toReturn = {
data: {
handle: 'test',
},
};
if (options && options.upload_tags) {
// @ts-ignore
toReturn.data.upload_tags = options.upload_tags;
}
return Promise.resolve(toReturn);
});
// @ts-ignore
Filelink.prototype.getTasks.mockImplementation(function () { return storeTaskDef; });
});
it('should call correct store method', function () { return __awaiter(void 0, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, storeURL({ session: mockedSession, url: sourceToStore })];
case 1:
_a.sent();
expect(FsRequest.post).toHaveBeenCalledWith("".concat(mockedSession.urls.processUrl, "/process"), {
apikey: mockedSession.apikey,
sources: [sourceToStore],
tasks: storeTaskDef,
upload_tags: undefined,
}, {});
return [2 /*return*/];
}
});
}); });
it('should respect passed security and policy', function () { return __awaiter(void 0, void 0, void 0, function () {
var fakeSecurity;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
fakeSecurity = {
signature: 'fakeS',
policy: 'fakeP',
};
return [4 /*yield*/, storeURL({ session: mockedSession, url: sourceToStore, security: fakeSecurity })];
case 1:
_a.sent();
expect(Filelink.prototype.security).toHaveBeenCalledWith(fakeSecurity);
expect(FsRequest.post).toHaveBeenCalledWith("".concat(mockedSession.urls.processUrl, "/process"), {
apikey: mockedSession.apikey,
sources: [sourceToStore],
tasks: storeTaskDef,
upload_tags: undefined,
}, {});
return [2 /*return*/];
}
});
}); });
it('should throw error on wrong store params', function () {
return expect(storeURL({
session: mockedSession,
url: sourceToStore,
storeParams: {
// @ts-ignore
test: 123,
},
})).rejects.toEqual(expect.any(FilestackError));
});
it('should respect token cancel', function () { return __awaiter(void 0, void 0, void 0, function () {
var token;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
token = {
cancel: function () {
console.log('cancel method');
},
};
return [4 /*yield*/, storeURL({
session: mockedSession,
url: sourceToStore,
token: token,
})];
case 1:
_a.sent();
expect(FsRequest.post).toHaveBeenCalledWith("".concat(mockedSession.urls.processUrl, "/process"), {
apikey: mockedSession.apikey,
sources: [sourceToStore],
tasks: storeTaskDef,
upload_tags: undefined,
// expect.any(FsCancelToken) is not working correctly with mocked functions
}, { cancelToken: expect.any(Object) });
return [2 /*return*/];
}
});
}); });
it('should pass upload tags to request', function () { return __awaiter(void 0, void 0, void 0, function () {
var uploadTags, res;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
uploadTags = { test: '123' };
return [4 /*yield*/, storeURL({
session: mockedSession,
url: sourceToStore,
uploadTags: uploadTags,
})];
case 1:
res = _a.sent();
expect(FsRequest.post).toHaveBeenCalledWith("".concat(mockedSession.urls.processUrl, "/process"), {
apikey: mockedSession.apikey,
sources: [sourceToStore],
tasks: storeTaskDef,
upload_tags: uploadTags,
}, {});
expect(res.uploadTags).toEqual(uploadTags);
return [2 /*return*/];
}
});
}); });
it('should throw an error when missing url', function () {
return expect(storeURL({ session: mockedSession })).rejects.toEqual(expect.any(FilestackError));
});
it('should throw on missing handle in response', function () {
// @ts-ignore
FsRequest.post.mockImplementation(function () { return Promise.resolve({
data: {},
}); });
return expect(storeURL({
session: mockedSession,
url: sourceToStore,
})).rejects.toEqual(expect.any(FilestackError));
});
it('should be able to run storeUrl with workflows', function () { return __awaiter(void 0, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, storeURL({
session: mockedSession,
url: sourceToStore,
workflowIds: workflowIds,
})];
case 1:
_a.sent();
expect(FsRequest.post).toHaveBeenCalledWith("".concat(mockedSession.urls.processUrl, "/process"), {
apikey: mockedSession.apikey,
sources: [sourceToStore],
tasks: storeTaskDefWithWorkflows,
}, {});
return [2 /*return*/];
}
});
}); });
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/api/store.spec.ts"],"names":[],"mappings":"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","file":"lib/api/store.spec.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 { storeURL } from './store';\nimport { Session } from '../client';\nimport { FilestackError } from './../../filestack_error';\n\nimport { config } from './../../config';\nimport { FsRequest } from './../request';\nimport { Filelink } from './../filelink';\n\njest.mock('./../filelink');\njest.mock('./../request');\n\nconst mockedSession: Session = {\n  apikey: 'fakeApikey',\n  urls: config.urls,\n};\n\nconst workflowIds = ['123', '321'];\n\nconst storeTaskDef = [{ name: 'store', params: {} }];\nconst storeTaskDefWithWorkflows = [{ name: 'store', params: {} }];\nconst sourceToStore = 'urlToStore';\n\ndescribe('StoreURL', () => {\n\n  beforeEach(() => {\n    // @ts-ignore\n    FsRequest.post.mockImplementation((_, options) => {\n      let toReturn = {\n        data: {\n          handle: 'test',\n        },\n      };\n\n      if (options && options.upload_tags) {\n        // @ts-ignore\n        toReturn.data.upload_tags = options.upload_tags;\n      }\n\n      return Promise.resolve(toReturn);\n    });\n\n    // @ts-ignore\n    Filelink.prototype.getTasks.mockImplementation(() => storeTaskDef);\n  });\n\n  it('should call correct store method', async () => {\n    await storeURL({ session: mockedSession, url: sourceToStore });\n\n    expect(FsRequest.post).toHaveBeenCalledWith(`${mockedSession.urls.processUrl}/process`, {\n      apikey: mockedSession.apikey,\n      sources: [ sourceToStore ],\n      tasks: storeTaskDef,\n      upload_tags: undefined,\n    }, {});\n  });\n\n  it('should respect passed security and policy', async () => {\n    const fakeSecurity = {\n      signature: 'fakeS',\n      policy: 'fakeP',\n    };\n\n    await storeURL({ session: mockedSession, url: sourceToStore, security: fakeSecurity });\n\n    expect(Filelink.prototype.security).toHaveBeenCalledWith(fakeSecurity);\n\n    expect(FsRequest.post).toHaveBeenCalledWith(`${mockedSession.urls.processUrl}/process`, {\n      apikey: mockedSession.apikey,\n      sources: [ sourceToStore ],\n      tasks: storeTaskDef,\n      upload_tags: undefined,\n    }, {});\n  });\n\n  it('should throw error on wrong store params', () => {\n    return expect(storeURL({\n      session: mockedSession,\n      url: sourceToStore,\n      storeParams: {\n        // @ts-ignore\n        test: 123,\n      },\n    })).rejects.toEqual(expect.any(FilestackError));\n  });\n\n  it('should respect token cancel', async () => {\n    // simulate old token\n    const token = {\n      cancel: () => {\n        console.log('cancel method');\n      },\n    };\n\n    await storeURL({\n      session: mockedSession,\n      url: sourceToStore,\n      token,\n    });\n\n    expect(FsRequest.post).toHaveBeenCalledWith(`${mockedSession.urls.processUrl}/process`, {\n      apikey: mockedSession.apikey,\n      sources: [ sourceToStore ],\n      tasks: storeTaskDef,\n      upload_tags: undefined,\n\n      // expect.any(FsCancelToken) is not working correctly with mocked functions\n    }, { cancelToken: expect.any(Object) });\n  });\n\n  it('should pass upload tags to request', async () => {\n    const uploadTags = { test: '123' };\n\n    const res = await storeURL({\n      session: mockedSession,\n      url: sourceToStore,\n      uploadTags,\n    });\n\n    expect(FsRequest.post).toHaveBeenCalledWith(`${mockedSession.urls.processUrl}/process`, {\n      apikey: mockedSession.apikey,\n      sources: [ sourceToStore ],\n      tasks: storeTaskDef,\n      upload_tags: uploadTags,\n    }, {});\n\n    expect(res.uploadTags).toEqual(uploadTags);\n  });\n\n  it('should throw an error when missing url', () => {\n    return expect(storeURL({ session: mockedSession })).rejects.toEqual(expect.any(FilestackError));\n  });\n\n  it('should throw on missing handle in response', () => {\n\n    // @ts-ignore\n    FsRequest.post.mockImplementation(() => Promise.resolve({\n      data: {},\n    }));\n\n    return expect(storeURL({\n      session: mockedSession,\n      url: sourceToStore,\n    })).rejects.toEqual(expect.any(FilestackError));\n  });\n\n  it('should be able to run storeUrl with workflows', async () => {\n    await storeURL({\n      session: mockedSession,\n      url: sourceToStore,\n      workflowIds,\n    });\n\n    expect(FsRequest.post).toHaveBeenCalledWith(`${mockedSession.urls.processUrl}/process`, {\n      apikey: mockedSession.apikey,\n      sources: [ sourceToStore ],\n      tasks: storeTaskDefWithWorkflows,\n    }, {});\n  });\n\n});\n"]}