browser_canvas-frontend-slider-02.js 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /* Any copyright is dedicated to the Public Domain.
  2. http://creativecommons.org/publicdomain/zero/1.0/ */
  3. /**
  4. * Tests if the slider in the calls list view works as advertised.
  5. */
  6. function* ifTestingSupported() {
  7. let { target, panel } = yield initCanvasDebuggerFrontend(SIMPLE_CANVAS_URL);
  8. let { window, $, EVENTS, gFront, SnapshotsListView, CallsListView } = panel.panelWin;
  9. yield reload(target);
  10. let recordingFinished = once(window, EVENTS.SNAPSHOT_RECORDING_FINISHED);
  11. let callListPopulated = once(window, EVENTS.CALL_LIST_POPULATED);
  12. let thumbnailsDisplayed = once(window, EVENTS.THUMBNAILS_DISPLAYED);
  13. SnapshotsListView._onRecordButtonClick();
  14. yield promise.all([recordingFinished, callListPopulated, thumbnailsDisplayed]);
  15. let firstSnapshot = SnapshotsListView.getItemAtIndex(0);
  16. let firstSnapshotOverview = yield firstSnapshot.attachment.actor.getOverview();
  17. let thumbnails = firstSnapshotOverview.thumbnails;
  18. is(thumbnails.length, 4,
  19. "There should be 4 thumbnails cached for the snapshot item.");
  20. let thumbnailImageElementSet = waitForMozSetImageElement(window);
  21. $("#calls-slider").value = 1;
  22. let thumbnailPixels = yield thumbnailImageElementSet;
  23. ok(sameArray(thumbnailPixels, thumbnails[0].pixels),
  24. "The screenshot element should have a thumbnail as an immediate background.");
  25. yield once(window, EVENTS.CALL_SCREENSHOT_DISPLAYED);
  26. ok(true, "The full-sized screenshot was displayed for the item at index 1.");
  27. thumbnailImageElementSet = waitForMozSetImageElement(window);
  28. $("#calls-slider").value = 2;
  29. thumbnailPixels = yield thumbnailImageElementSet;
  30. ok(sameArray(thumbnailPixels, thumbnails[1].pixels),
  31. "The screenshot element should have a thumbnail as an immediate background.");
  32. yield once(window, EVENTS.CALL_SCREENSHOT_DISPLAYED);
  33. ok(true, "The full-sized screenshot was displayed for the item at index 2.");
  34. thumbnailImageElementSet = waitForMozSetImageElement(window);
  35. $("#calls-slider").value = 7;
  36. thumbnailPixels = yield thumbnailImageElementSet;
  37. ok(sameArray(thumbnailPixels, thumbnails[3].pixels),
  38. "The screenshot element should have a thumbnail as an immediate background.");
  39. yield once(window, EVENTS.CALL_SCREENSHOT_DISPLAYED);
  40. ok(true, "The full-sized screenshot was displayed for the item at index 7.");
  41. thumbnailImageElementSet = waitForMozSetImageElement(window);
  42. $("#calls-slider").value = 4;
  43. thumbnailPixels = yield thumbnailImageElementSet;
  44. ok(sameArray(thumbnailPixels, thumbnails[2].pixels),
  45. "The screenshot element should have a thumbnail as an immediate background.");
  46. yield once(window, EVENTS.CALL_SCREENSHOT_DISPLAYED);
  47. ok(true, "The full-sized screenshot was displayed for the item at index 4.");
  48. thumbnailImageElementSet = waitForMozSetImageElement(window);
  49. $("#calls-slider").value = 0;
  50. thumbnailPixels = yield thumbnailImageElementSet;
  51. ok(sameArray(thumbnailPixels, thumbnails[0].pixels),
  52. "The screenshot element should have a thumbnail as an immediate background.");
  53. yield once(window, EVENTS.CALL_SCREENSHOT_DISPLAYED);
  54. ok(true, "The full-sized screenshot was displayed for the item at index 0.");
  55. yield teardown(panel);
  56. finish();
  57. }
  58. function waitForMozSetImageElement(panel) {
  59. let deferred = promise.defer();
  60. panel._onMozSetImageElement = deferred.resolve;
  61. return deferred.promise;
  62. }
  63. function sameArray(a, b) {
  64. if (a.length != b.length) {
  65. return false;
  66. }
  67. for (let i = 0; i < a.length; i++) {
  68. if (a[i] !== b[i]) {
  69. return false;
  70. }
  71. }
  72. return true;
  73. }