filestack-js
Version:
Official JavaScript library for Filestack
393 lines (391 loc) • 47.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
var tslib_1 = require("tslib");
/*
* 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.
*/
var filestack_error_1 = require("./../filestack_error");
var config_1 = require("./../config");
var client_1 = require("./client");
var cloud_1 = require("./api/cloud");
var upload_1 = require("./api/upload/upload");
var picker_1 = require("./picker");
var preview_1 = require("./api/preview");
var file_1 = require("./api/file");
var store_1 = require("./api/store");
var transform_1 = require("./api/transform");
jest.mock('./api/upload/upload');
jest.mock('./api/cloud');
jest.mock('./api/file');
jest.mock('./api/store');
jest.mock('./picker');
jest.mock('./api/preview');
jest.mock('./api/transform');
describe('client', function () {
var defaultApikey = 'EXAMPLE_API_KEY';
var defaultHandle = 'EXAMPLE_HANDLE';
var defaultSecurity = {
policy: 'examplePolicy',
signature: 'exampleSignature',
};
var sessionURls = config_1.config.urls;
var defaultSession = {
apikey: defaultApikey,
urls: sessionURls,
};
it('should properly instantiate Client', function () {
var client = new client_1.Client(defaultApikey);
expect(client).toBeDefined();
expect(client).toBeInstanceOf(client_1.Client);
});
it('should throw an error if api key not provided', function () {
expect(function () {
return new client_1.Client('');
}).toThrow('An apikey is required to initialize the Filestack client');
});
it('should throw an error if provided security without signature', function () {
var options = {
security: {
policy: 'examplePolicy',
signature: '',
},
};
expect(function () {
return new client_1.Client(defaultApikey, options);
}).toThrow('Both policy and signature are required for client security');
});
it('should pass policy & signature to the session', function () {
var options = {
security: defaultSecurity,
};
var client = new client_1.Client(defaultApikey, options);
expect(client.session.policy).toBe(options.security.policy);
expect(client.session.signature).toBe(options.security.signature);
});
it('should pass cname to the session', function () {
var options = {
cname: 'testCname.com',
};
var client = new client_1.Client(defaultApikey, options);
expect(client.session.cname).toBe(options.cname);
});
it('should be able to logout for provied cloud', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, cloudName;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
cloudName = 'dropbox';
return [4 /*yield*/, client.logout(cloudName)];
case 1:
_a.sent();
expect(cloud_1.CloudClient.prototype.logout).toHaveBeenCalledWith(cloudName);
return [2 /*return*/];
}
});
}); });
it('should get metadata for a provided handle', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, options;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
options = {
sha224: true,
};
return [4 /*yield*/, client.metadata(defaultHandle, options, defaultSecurity)];
case 1:
_a.sent();
expect(file_1.metadata).toHaveBeenCalledWith(defaultSession, defaultHandle, options, defaultSecurity);
return [2 /*return*/];
}
});
}); });
it('should be able to open picker', function () {
var client = new client_1.Client(defaultApikey);
var pickerOptions = {
lang: 'de',
};
client.picker(pickerOptions);
expect(picker_1.picker).toHaveBeenCalledWith(client, pickerOptions);
});
it('should be able to open preview', function () {
var client = new client_1.Client(defaultApikey);
var previewOptions = {
id: 'testElement',
};
client.preview(defaultHandle, previewOptions);
expect(preview_1.preview).toHaveBeenCalledWith(defaultSession, defaultHandle, previewOptions);
});
it('should be able to remove handle', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
return [4 /*yield*/, client.remove(defaultHandle, defaultSecurity)];
case 1:
_a.sent();
expect(file_1.remove).toHaveBeenCalledWith(defaultSession, defaultHandle, false, defaultSecurity);
return [2 /*return*/];
}
});
}); });
it('should be able to remove metadata', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
return [4 /*yield*/, client.removeMetadata(defaultHandle, defaultSecurity)];
case 1:
_a.sent();
expect(file_1.remove).toHaveBeenCalledWith(defaultSession, defaultHandle, true, defaultSecurity);
return [2 /*return*/];
}
});
}); });
it('should be able to store url', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, url, options, token, uploadTags, headers, workflowIds;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
url = 'http://example.com/img3.jpg';
options = {};
token = {};
uploadTags = { test: '123' };
headers = { 'test': '123' };
workflowIds = ['123', '321'];
return [4 /*yield*/, client.storeURL(url, options, token, defaultSecurity, uploadTags, headers, workflowIds)];
case 1:
_a.sent();
expect(store_1.storeURL).toHaveBeenCalledWith({
session: defaultSession,
url: url,
storeParams: options,
token: token,
security: defaultSecurity,
uploadTags: uploadTags,
headers: headers,
workflowIds: workflowIds,
});
return [2 /*return*/];
}
});
}); });
it('should be able to retrieve handle', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, retrieveOptions;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
retrieveOptions = {};
return [4 /*yield*/, client.retrieve(defaultHandle, retrieveOptions, defaultSecurity)];
case 1:
_a.sent();
expect(file_1.retrieve).toHaveBeenCalledWith(defaultSession, defaultHandle, retrieveOptions, defaultSecurity);
return [2 /*return*/];
}
});
}); });
it('should be able to transform url with b64', function () {
var client = new client_1.Client(defaultApikey);
var transformOptions = {
blur: {
amount: 5,
},
};
var b64 = true;
client.transform(defaultHandle, transformOptions, b64);
expect(transform_1.transform).toHaveBeenCalledWith(defaultSession, defaultHandle, transformOptions, b64);
});
it('should be able to transform url without b64', function () {
var client = new client_1.Client(defaultApikey);
var transformOptions = {
blur: {
amount: 5,
},
};
client.transform(defaultHandle, transformOptions);
expect(transform_1.transform).toHaveBeenCalledWith(defaultSession, defaultHandle, transformOptions, false);
});
it('should be able to upload file', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, file, uploadOptions, storeOptions, token;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
file = 'anyFile';
uploadOptions = {};
storeOptions = {};
token = {};
jest.spyOn(upload_1.Upload.prototype, 'upload').mockImplementation(function () { return Promise.resolve(); });
return [4 /*yield*/, client.upload(file, uploadOptions, storeOptions, token, defaultSecurity)];
case 1:
_a.sent();
expect(upload_1.Upload.prototype.setSession).toHaveBeenCalledWith({
apikey: defaultApikey,
urls: sessionURls,
});
expect(upload_1.Upload.prototype.setToken).toHaveBeenCalledWith(token);
expect(upload_1.Upload.prototype.setSecurity).toHaveBeenCalledWith(defaultSecurity);
expect(upload_1.Upload.prototype.upload).toHaveBeenCalledWith(file);
return [2 /*return*/];
}
});
}); });
it('should be able to upload file with alt text', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, file, uploadOptions, storeOptions, token;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
file = 'anyFile';
uploadOptions = {};
storeOptions = {};
token = {};
jest.spyOn(upload_1.Upload.prototype, 'upload').mockImplementation(function () { return Promise.resolve(); });
return [4 /*yield*/, client.upload(file, uploadOptions, storeOptions, token, defaultSecurity)];
case 1:
_a.sent();
expect(upload_1.Upload.prototype.setSession).toHaveBeenCalledWith({
apikey: defaultApikey,
urls: sessionURls,
});
expect(upload_1.Upload.prototype.setToken).toHaveBeenCalledWith(token);
expect(upload_1.Upload.prototype.setSecurity).toHaveBeenCalledWith(defaultSecurity);
expect(upload_1.Upload.prototype.upload).toHaveBeenCalledWith(file);
return [2 /*return*/];
}
});
}); });
it('should be able to upload file without token and security', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, file, uploadOptions, storeOptions;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
file = 'anyFile';
uploadOptions = {};
storeOptions = {};
jest.spyOn(upload_1.Upload.prototype, 'upload').mockImplementation(function () { return Promise.resolve(); });
return [4 /*yield*/, client.upload(file, uploadOptions, storeOptions)];
case 1:
_a.sent();
expect(upload_1.Upload.prototype.setSession).toHaveBeenCalledWith({
apikey: defaultApikey,
urls: sessionURls,
});
expect(upload_1.Upload.prototype.upload).toHaveBeenCalledWith(file);
return [2 /*return*/];
}
});
}); });
it('should emit error', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, file, uploadOptions, storeOptions, token, mockOnError, test;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
file = 'anyFile';
uploadOptions = {};
storeOptions = {};
token = {};
mockOnError = jest.fn().mockName('mockOnError');
test = new filestack_error_1.FilestackError('test');
client.on('upload.error', mockOnError);
jest.spyOn(upload_1.Upload.prototype, 'on').mockImplementation(function (name, cb, ctx) { return cb(test); });
return [4 /*yield*/, client.upload(file, uploadOptions, storeOptions, token, defaultSecurity)];
case 1:
_a.sent();
expect(mockOnError).toHaveBeenCalledWith(test);
return [2 /*return*/];
}
});
}); });
it('should be able to multiupload file', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, files, uploadOptions, storeOptions, token;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
files = ['anyFile'];
uploadOptions = {};
storeOptions = {};
token = {};
jest.spyOn(upload_1.Upload.prototype, 'multiupload').mockImplementation(function () { return Promise.resolve(); });
return [4 /*yield*/, client.multiupload(files, uploadOptions, storeOptions, token, defaultSecurity)];
case 1:
_a.sent();
expect(upload_1.Upload.prototype.setSession).toHaveBeenCalledWith({
apikey: defaultApikey,
urls: sessionURls,
});
expect(upload_1.Upload.prototype.setToken).toHaveBeenCalledWith(token);
expect(upload_1.Upload.prototype.setSecurity).toHaveBeenCalledWith(defaultSecurity);
expect(upload_1.Upload.prototype.multiupload).toHaveBeenCalledWith(files);
return [2 /*return*/];
}
});
}); });
it('should call multiupload without security or token', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, files, uploadOptions, storeOptions;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
files = ['anyFile'];
uploadOptions = {};
storeOptions = {};
jest.spyOn(upload_1.Upload.prototype, 'multiupload').mockImplementation(function () { return Promise.resolve(); });
return [4 /*yield*/, client.multiupload(files, uploadOptions, storeOptions)];
case 1:
_a.sent();
expect(upload_1.Upload.prototype.setSession).toHaveBeenCalledWith({
apikey: defaultApikey,
urls: sessionURls,
});
expect(upload_1.Upload.prototype.multiupload).toHaveBeenCalledWith(files);
return [2 /*return*/];
}
});
}); });
it('should emit error for multiupload', function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
var client, files, uploadOptions, storeOptions, token, mockOnError, test;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
client = new client_1.Client(defaultApikey);
files = ['anyFile'];
uploadOptions = {};
storeOptions = {};
token = {};
jest.spyOn(upload_1.Upload.prototype, 'multiupload').mockImplementation(function () { return Promise.resolve(); });
mockOnError = jest.fn().mockName('mockOnError');
test = new filestack_error_1.FilestackError('test');
client.on('upload.error', mockOnError);
jest.spyOn(upload_1.Upload.prototype, 'on').mockImplementation(function (name, cb, ctx) { return cb(test); });
return [4 /*yield*/, client.multiupload(files, uploadOptions, storeOptions, token, defaultSecurity)];
case 1:
_a.sent();
expect(mockOnError).toHaveBeenCalledWith(test);
return [2 /*return*/];
}
});
}); });
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../../src/lib/client.spec.ts"],"names":[],"mappings":"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","file":"lib/client.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 */\nimport { FilestackError } from './../filestack_error';\nimport { config } from './../config';\nimport { Client } from './client';\nimport { CloudClient } from './api/cloud';\nimport { Upload } from './api/upload/upload';\nimport { picker } from './picker';\nimport { preview } from './api/preview';\nimport { metadata, remove, retrieve } from './api/file';\nimport { storeURL } from './api/store';\nimport { transform } from './api/transform';\n\njest.mock('./api/upload/upload');\njest.mock('./api/cloud');\njest.mock('./api/file');\njest.mock('./api/store');\njest.mock('./picker');\njest.mock('./api/preview');\njest.mock('./api/transform');\n\ndescribe('client', () => {\n  const defaultApikey = 'EXAMPLE_API_KEY';\n  const defaultHandle = 'EXAMPLE_HANDLE';\n  const defaultSecurity = {\n    policy: 'examplePolicy',\n    signature: 'exampleSignature',\n  };\n\n  const sessionURls = config.urls;\n  const defaultSession = {\n    apikey: defaultApikey,\n    urls: sessionURls,\n  };\n\n  it('should properly instantiate Client', () => {\n    const client = new Client(defaultApikey);\n    expect(client).toBeDefined();\n    expect(client).toBeInstanceOf(Client);\n  });\n\n  it('should throw an error if api key not provided', () => {\n    expect(() => {\n      return new Client('');\n    }).toThrow('An apikey is required to initialize the Filestack client');\n  });\n\n  it('should throw an error if provided security without signature', () => {\n    const options = {\n      security: {\n        policy: 'examplePolicy',\n        signature: '',\n      },\n    };\n    expect(() => {\n      return new Client(defaultApikey, options);\n    }).toThrow('Both policy and signature are required for client security');\n  });\n\n  it('should pass policy & signature to the session', () => {\n    const options = {\n      security: defaultSecurity,\n    };\n    const client = new Client(defaultApikey, options);\n    expect(client.session.policy).toBe(options.security.policy);\n    expect(client.session.signature).toBe(options.security.signature);\n  });\n\n  it('should pass cname to the session', () => {\n    const options = {\n      cname: 'testCname.com',\n    };\n    const client = new Client(defaultApikey, options);\n    expect(client.session.cname).toBe(options.cname);\n  });\n\n  it('should be able to logout for provied cloud', async () => {\n    const client = new Client(defaultApikey);\n    const cloudName = 'dropbox';\n    await client.logout(cloudName);\n\n    expect(CloudClient.prototype.logout).toHaveBeenCalledWith(cloudName);\n  });\n\n  it('should get metadata for a provided handle', async () => {\n    const client = new Client(defaultApikey);\n    const options = {\n      sha224: true,\n    };\n\n    await client.metadata(defaultHandle, options, defaultSecurity);\n    expect(metadata).toHaveBeenCalledWith(defaultSession, defaultHandle, options, defaultSecurity);\n  });\n\n  it('should be able to open picker', () => {\n    const client = new Client(defaultApikey);\n    const pickerOptions = {\n      lang: 'de',\n    };\n    client.picker(pickerOptions);\n\n    expect(picker).toHaveBeenCalledWith(client, pickerOptions);\n  });\n\n  it('should be able to open preview', () => {\n    const client = new Client(defaultApikey);\n    const previewOptions = {\n      id: 'testElement',\n    };\n    client.preview(defaultHandle, previewOptions);\n\n    expect(preview).toHaveBeenCalledWith(defaultSession, defaultHandle, previewOptions);\n  });\n\n  it('should be able to remove handle', async () => {\n    const client = new Client(defaultApikey);\n    await client.remove(defaultHandle, defaultSecurity);\n    expect(remove).toHaveBeenCalledWith(defaultSession, defaultHandle, false, defaultSecurity);\n  });\n\n  it('should be able to remove metadata', async () => {\n    const client = new Client(defaultApikey);\n    await client.removeMetadata(defaultHandle, defaultSecurity);\n\n    expect(remove).toHaveBeenCalledWith(defaultSession, defaultHandle, true, defaultSecurity);\n  });\n\n  it('should be able to store url', async () => {\n    const client = new Client(defaultApikey);\n    const url = 'http://example.com/img3.jpg';\n    const options = {};\n    const token = {};\n    const uploadTags = { test: '123' };\n    const headers = { 'test': '123' };\n    const workflowIds = ['123', '321'];\n    await client.storeURL(url, options, token, defaultSecurity, uploadTags,headers, workflowIds);\n\n    expect(storeURL).toHaveBeenCalledWith({\n      session: defaultSession,\n      url,\n      storeParams: options,\n      token,\n      security: defaultSecurity,\n      uploadTags,\n      headers,\n      workflowIds,\n    });\n  });\n\n  it('should be able to retrieve handle', async () => {\n    const client = new Client(defaultApikey);\n    const retrieveOptions = {};\n\n    await client.retrieve(defaultHandle, retrieveOptions, defaultSecurity);\n    expect(retrieve).toHaveBeenCalledWith(defaultSession, defaultHandle, retrieveOptions, defaultSecurity);\n  });\n\n  it('should be able to transform url with b64', () => {\n    const client = new Client(defaultApikey);\n    const transformOptions = {\n      blur: {\n        amount: 5,\n      },\n    };\n    const b64 = true;\n    client.transform(defaultHandle, transformOptions, b64);\n    expect(transform).toHaveBeenCalledWith(defaultSession, defaultHandle, transformOptions, b64);\n  });\n\n  it('should be able to transform url without b64', () => {\n    const client = new Client(defaultApikey);\n    const transformOptions = {\n      blur: {\n        amount: 5,\n      },\n    };\n    client.transform(defaultHandle, transformOptions);\n    expect(transform).toHaveBeenCalledWith(defaultSession, defaultHandle, transformOptions, false);\n  });\n\n  it('should be able to upload file', async () => {\n    const client = new Client(defaultApikey);\n    const file = 'anyFile';\n    const uploadOptions = {};\n    const storeOptions = {};\n    const token = {};\n\n    jest.spyOn(Upload.prototype, 'upload').mockImplementation(() => Promise.resolve());\n\n    await client.upload(file, uploadOptions, storeOptions, token, defaultSecurity);\n\n    expect(Upload.prototype.setSession).toHaveBeenCalledWith({\n      apikey: defaultApikey,\n      urls: sessionURls,\n    });\n\n    expect(Upload.prototype.setToken).toHaveBeenCalledWith(token);\n    expect(Upload.prototype.setSecurity).toHaveBeenCalledWith(defaultSecurity);\n    expect(Upload.prototype.upload).toHaveBeenCalledWith(file);\n  });\n\n  it('should be able to upload file with alt text', async () => {\n    const client = new Client(defaultApikey);\n    const file = 'anyFile';\n    const uploadOptions = {};\n    const storeOptions = {};\n    const token = {};\n\n    jest.spyOn(Upload.prototype, 'upload').mockImplementation(() => Promise.resolve());\n\n    await client.upload(file, uploadOptions, storeOptions, token, defaultSecurity);\n\n    expect(Upload.prototype.setSession).toHaveBeenCalledWith({\n      apikey: defaultApikey,\n      urls: sessionURls,\n    });\n\n    expect(Upload.prototype.setToken).toHaveBeenCalledWith(token);\n    expect(Upload.prototype.setSecurity).toHaveBeenCalledWith(defaultSecurity);\n    expect(Upload.prototype.upload).toHaveBeenCalledWith(file);\n  });\n\n  it('should be able to upload file without token and security', async () => {\n    const client = new Client(defaultApikey);\n    const file = 'anyFile';\n    const uploadOptions = {};\n    const storeOptions = {};\n\n    jest.spyOn(Upload.prototype, 'upload').mockImplementation(() => Promise.resolve());\n\n    await client.upload(file, uploadOptions, storeOptions);\n\n    expect(Upload.prototype.setSession).toHaveBeenCalledWith({\n      apikey: defaultApikey,\n      urls: sessionURls,\n    });\n\n    expect(Upload.prototype.upload).toHaveBeenCalledWith(file);\n  });\n\n  it('should emit error', async () => {\n    const client = new Client(defaultApikey);\n    const file = 'anyFile';\n    const uploadOptions = {};\n    const storeOptions = {};\n    const token = {};\n    const mockOnError = jest.fn().mockName('mockOnError');\n\n    const test = new FilestackError('test');\n\n    client.on('upload.error', mockOnError);\n\n    jest.spyOn(Upload.prototype, 'on').mockImplementation((name, cb, ctx): any => cb(test));\n\n    await client.upload(file, uploadOptions, storeOptions, token, defaultSecurity);\n\n    expect(mockOnError).toHaveBeenCalledWith(test);\n  });\n\n  it('should be able to multiupload file', async () => {\n    const client = new Client(defaultApikey);\n    const files = ['anyFile'];\n    const uploadOptions = {};\n    const storeOptions = {};\n    const token = {};\n\n    jest.spyOn(Upload.prototype, 'multiupload').mockImplementation(() => Promise.resolve());\n\n    await client.multiupload(files, uploadOptions, storeOptions, token, defaultSecurity);\n\n    expect(Upload.prototype.setSession).toHaveBeenCalledWith({\n      apikey: defaultApikey,\n      urls: sessionURls,\n    });\n\n    expect(Upload.prototype.setToken).toHaveBeenCalledWith(token);\n    expect(Upload.prototype.setSecurity).toHaveBeenCalledWith(defaultSecurity);\n    expect(Upload.prototype.multiupload).toHaveBeenCalledWith(files);\n  });\n\n  it('should call multiupload without security or token', async () => {\n    const client = new Client(defaultApikey);\n    const files = ['anyFile'];\n    const uploadOptions = {};\n    const storeOptions = {};\n\n    jest.spyOn(Upload.prototype, 'multiupload').mockImplementation(() => Promise.resolve());\n\n    await client.multiupload(files, uploadOptions, storeOptions);\n\n    expect(Upload.prototype.setSession).toHaveBeenCalledWith({\n      apikey: defaultApikey,\n      urls: sessionURls,\n    });\n\n    expect(Upload.prototype.multiupload).toHaveBeenCalledWith(files);\n  });\n\n  it('should emit error for multiupload', async () => {\n    const client = new Client(defaultApikey);\n    const files = ['anyFile'];\n    const uploadOptions = {};\n    const storeOptions = {};\n    const token = {};\n\n    jest.spyOn(Upload.prototype, 'multiupload').mockImplementation(() => Promise.resolve());\n\n    const mockOnError = jest.fn().mockName('mockOnError');\n\n    const test = new FilestackError('test');\n\n    client.on('upload.error', mockOnError);\n\n    jest.spyOn(Upload.prototype, 'on').mockImplementation((name, cb, ctx): any => cb(test));\n\n    await client.multiupload(files, uploadOptions, storeOptions, token, defaultSecurity);\n\n    expect(mockOnError).toHaveBeenCalledWith(test);\n  });\n});\n"]}