Files
shaka-player/test/offline/offline_scheme_unit.js
T
Jacob Trimble 94a47ec61f Add a generic test filter.
This add a filterDescribe that can be used to filter groups of tests
based on platform support.  This consolidates the different test
filtering to one place.

Change-Id: I8f320fcf0edfa2d984433890fcfc3714e78b195b
2019-06-07 18:56:38 +00:00

166 lines
4.9 KiB
JavaScript

/**
* @license
* Copyright 2016 Google Inc.
*
* 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.
*/
/** @return {boolean} */
const offlineSchemeSupport = () => shaka.offline.StorageMuxer.support();
filterDescribe('OfflineScheme', offlineSchemeSupport, () => {
// An arbitrary request type.
const requestType = shaka.net.NetworkingEngine.RequestType.MANIFEST;
// A dummy progress callback.
const progressUpdated = (elapsedMs, bytes, bytesRemaining) => {};
const Util = shaka.test.Util;
beforeEach(async () => {
// Make sure we start with a clean slate.
await clearStorage();
});
afterEach(async () => {
// Make sure that we don't waste storage by leaving stuff in storage.
await clearStorage();
});
it('returns special content-type header for manifests', async () => {
const expectedContentType = 'application/x-offline-manifest';
const request = createRequest();
/** @type {!shaka.offline.OfflineUri} */
const uri = shaka.offline.OfflineUri.manifest(
'mechanism', 'cell', 1024);
const response = await shaka.offline.OfflineScheme.plugin(
uri.toString(), request, requestType, progressUpdated).promise;
expect(response).toBeTruthy();
expect(response.uri).toBe(uri.toString());
expect(response.headers['content-type']).toBe(expectedContentType);
});
it('returns segment data from storage', async () => {
const request = createRequest();
const segment = createSegment();
/** @type {!shaka.offline.OfflineUri} */
let uri;
/** @type {!shaka.offline.StorageMuxer} */
const muxer = new shaka.offline.StorageMuxer();
try {
await muxer.init();
const handle = await muxer.getActive();
const keys = await handle.cell.addSegments([segment]);
uri = shaka.offline.OfflineUri.segment(
handle.path.mechanism, handle.path.cell, keys[0]);
} finally {
await muxer.destroy();
}
const response = await shaka.offline.OfflineScheme.plugin(
uri.toString(), request, requestType, progressUpdated).promise;
expect(response).toBeTruthy();
expect(response.data.byteLength).toBe(segment.data.byteLength);
});
it('fails if segment not found', async () => {
const request = createRequest();
/** @type {!shaka.offline.OfflineUri} */
let uri;
/** @type {!shaka.offline.StorageMuxer} */
const muxer = new shaka.offline.StorageMuxer();
try {
await muxer.init();
const handle = await muxer.getActive();
// Create a bad uri by using the mechanism and cell of the active cell
// but use a key that is not in use.
const badKey = 1000000;
uri = shaka.offline.OfflineUri.segment(
handle.path.mechanism, handle.path.cell, badKey);
} finally {
await muxer.destroy();
}
const expected = Util.jasmineError(new shaka.util.Error(
shaka.util.Error.Severity.CRITICAL,
shaka.util.Error.Category.STORAGE,
shaka.util.Error.Code.KEY_NOT_FOUND,
jasmine.any(String)));
await expectAsync(
shaka.offline.OfflineScheme.plugin(
uri.toString(), request, requestType, progressUpdated).promise)
.toBeRejectedWith(expected);
});
it('fails for invalid URI', async () => {
const request = createRequest();
const uri = 'this-in-an-invalid-uri';
const expected = Util.jasmineError(new shaka.util.Error(
shaka.util.Error.Severity.CRITICAL,
shaka.util.Error.Category.NETWORK,
shaka.util.Error.Code.MALFORMED_OFFLINE_URI,
uri));
await expectAsync(
shaka.offline.OfflineScheme.plugin(
uri, request, requestType, progressUpdated).promise)
.toBeRejectedWith(expected);
});
/**
* @return {shaka.extern.Request}
*/
function createRequest() {
const retry = shaka.net.NetworkingEngine.defaultRetryParameters();
const request = shaka.net.NetworkingEngine.makeRequest([], retry);
return request;
}
/**
* @return {shaka.extern.SegmentDataDB}
*/
function createSegment() {
const dataLength = 12;
const segment = {
data: new ArrayBuffer(dataLength),
};
return segment;
}
/**
* @return {!Promise}
*/
async function clearStorage() {
/** @type {!shaka.offline.StorageMuxer} */
const muxer = new shaka.offline.StorageMuxer();
try {
await muxer.erase();
} finally {
await muxer.destroy;
}
}
});