Add tests that loads mskp and changes frame.

Bug: skia:9462
Change-Id: I54141ffa4db7d5eb77e2e3d1b464ee540be3cd4d
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/244076
Reviewed-by: Kevin Lubick <kjlubick@google.com>
Commit-Queue: Nathaniel Nifong <nifong@google.com>
This commit is contained in:
Nathaniel Nifong 2019-09-25 13:35:43 -04:00 committed by Skia Commit-Bot
parent 19ae4aa4da
commit 696933d8ba
3 changed files with 66 additions and 0 deletions

Binary file not shown.

View File

@ -12,6 +12,7 @@ module.exports = function(config) {
files: [
{ pattern: 'debugger/bin/debugger.wasm', included:false, served:true},
{ pattern: 'debugger/sample.skp', included:false, served:true},
{ pattern: 'debugger/anim.mskp', included:false, served:true},
'../../modules/pathkit/tests/testReporter.js',
'debugger/bin/debugger.js',
'tests/debuggerinit.js',

View File

@ -0,0 +1,65 @@
// The increased timeout is especially needed with larger binaries
// like in the debug/gpu build
jasmine.DEFAULT_TIMEOUT_INTERVAL = 20000;
describe('Debugger\'s Playback Behavior', function() {
const container = document.createElement('div');
document.body.appendChild(container);
beforeEach(function() {
container.innerHTML = `<canvas id=debugger_view width=720 height=1280></canvas>`;
});
afterEach(function() {
container.innerHTML = '';
});
it('can switch to the second frame of an animated skp', function(done) {
const filename = '/debugger/anim.mskp'
const fetchSkpPromise = fetch(filename);
Promise.all([LoadDebugger, fetchSkpPromise]).then((values) => {
const response = values[1];
if (!response.ok) {
throw new Error("HTTP error, status = " + response.status);
}
response.arrayBuffer().then((buffer) => {
catchException(done, () => {
const canvasElement = document.getElementById('debugger_view');
const fileContents = new Uint8Array(buffer);
console.log('fetched '+filename);
const player = Debugger.SkpFilePlayer(fileContents);
const bounds = player.getBounds();
canvasElement.width = bounds.fRight - bounds.fLeft;
canvasElement.height = bounds.fBottom - bounds.fTop;
expect(canvasElement.width).toBe(1080);
expect(canvasElement.height).toBe(1920);
const surface = Debugger.MakeWebGLCanvasSurface(canvasElement);
expect(surface).toBeTruthy();
const numFrames = player.getFrameCount();
expect(numFrames).toBe(10);
let cmd = JSON.parse(player.jsonCommandList(surface));
expect(cmd).toBeTruthy();
// Move to last command in first frame
player.drawTo(surface, cmd.commands.length);
surface.flush();
// Move to frame two
player.changeFrame(1);
cmd = JSON.parse(player.jsonCommandList(surface));
expect(cmd).toBeTruthy();
// move to command 100 in frame 2
player.drawTo(surface, 100);
surface.flush();
console.log('drew picture to canvas element');
surface.dispose();
done();
})();
});
});
});
});