Closed Bug 993276 Opened 10 years ago Closed 10 years ago

[Calendar] Screenshot reference test for launch timing.

Categories

(Firefox OS Graveyard :: Gaia::Calendar, defect)

x86
macOS
defect
Not set
normal

Tracking

(Not tracked)

RESOLVED WONTFIX

People

(Reporter: evanxd, Assigned: evanxd)

References

Details

Attachments

(1 file, 2 obsolete files)

46 bytes, text/x-github-pull-request
Details | Review
Screenshot reference test for launch time.
For more details, please refer to https://bugzilla.mozilla.org/show_bug.cgi?id=984726#c11.
Attached file Pull request (obsolete) —
Comment on attachment 8403913 [details] [review]
Pull request

Hi Kevin,

Could you help me to review the patch?
Thanks.
Attachment #8403913 - Flags: review?(kgrandon)
The patch was already passed on Travis, see it at https://travis-ci.org/mozilla-b2g/gaia/builds/22600817.
Summary: Screenshot reference test for launch time. → Screenshot reference test for launch timing.
Comment on attachment 8403913 [details] [review]
Pull request

That was quick, awesome! I feel strongly that we should have a console.log of the image data when they do not match, and probably wrap this inside of a helper function. What do you think?
Attachment #8403913 - Flags: review?(kgrandon)
Hi Kevin,

For printing the base64 image when they do not match, we could just do this at https://github.com/evanxd/gaia/blob/053f90262e3e4035426e9110348179d706808e81/apps/calendar/test/marionette/screenshot_ref_test.js#L26-L30. It will print the expected and actual images on terminal. It is what we want, right?
Comment on attachment 8403913 [details] [review]
Pull request

Hi Kevin,

I already updated the patch for the comments.
Please help me to review the patch.

Thanks.
Attachment #8403913 - Flags: review?(kgrandon)
Calendar has had a lot of test problems because of changes in date because it uses the current system clock.  It doesn't look like this test is doing anything special to lock down the date.  Has Calendar's behaviour test-wise changed in this regard?
Hi Andrew,

Good point.
No, we don't do that yet in the patch.

So if we just set a fixed date before run the test, does it make sense?
Attachment #8403913 - Flags: review?(kgrandon)
Attached file Pull request (obsolete) —
Attachment #8403913 - Attachment is obsolete: true
Status: NEW → ASSIGNED
Attached file Pull request
Attachment #8404566 - Attachment is obsolete: true
Hi Kevin,

I have no good idea to deal with the timing issue at Comment 7 currently.
I think changing the system date with using `mozTime` might be not good idea.
Because we need to change settings app and do executeScript with `mozTime`, it looks hacking and unusual.

So could we do screenshot reference test for advanced settings view first?
But the screenshot looks weird, see .

How do you think?
Flags: needinfo?(kgrandon)
That is disheartening. It sounds like there are two known issues that we need to solve before we can really do this then.

1 - Freezing/setting of the system clock.
2 - Screenshot boundry after using transforms on panels. This one isn't really a blocker, but it just seems really janky to implement screenshots without having a proper viewport.

I would personally prefer to fix these two things before we try to implement these tests, though this may require platform work.

Perhaps we should open two bugs for this and block bug 984726 on them?
Flags: needinfo?(kgrandon)
Sure, let's file bugs.
Hi Kevin,

But for the time issues, could we just trigger the `changeDate` method https://github.com/mozilla-b2g/gaia/blob/master/apps/calendar/js/views/time_parent.js#L171 to instead of freezing system clock for setting a fixed time in Calendar app? How do you think about this?
Flags: needinfo?(kgrandon)
I could see pros and cons of doing it either way. If for example we adopt this testing strategy in other apps, they would have to have their own solution for freezing the date. Probably worth running this by Gareth and Andrew Sutherland real quick to get their thoughts. (Or just mark them as review? on the patch maybe)
Flags: needinfo?(kgrandon)
Summary: Screenshot reference test for launch timing. → [Calendar] Screenshot reference test for launch timing.
Hi Andrew,

Excuse me.
How do you think about the time issue you said at Comment 7?

Currently we have two solution for that.
1. do executeScript for `changeDate` method in Calendar's code base.
2. switch to Settings app and then do `mozTime.set()` to set system clock.

Do you have another good idea to fix the issue?
Thanks.
Flags: needinfo?(bugmail)
I think messing with the actual system clock is a recipe for trouble assuming you can do it at all.  (:gaye and :millermedeiros and I talked about this briefly and I think I was suggesting that even if we used https://developer.mozilla.org/en-US/docs/WebAPI/Time_and_Clock it's still quite possible that paravirtualized/jail-type executions will refuse to pretend the time is anything other than what the enclosing system's clock is.)

The e-mail back-end already has the ability to pretend the current time is something other than what it really is.  Which mainly leaves the e-mail UI which uses shared/js/l10n_date.js's non-standard fromNow method.  We could probably teach l10n_date.js:prettyDate() to lie and use a fake time instead of its use of Date.now().  We could then add a helper in shared/test/integration to executeScript to force that time to be set.

If we wanted to get super-fancy, we could augment one of our existing Marionette plugins to have an event emitter going on so we could do something like:

  client.helper.on('timewarp', function(timeSinceEpochMillis) {
    // I am doing my own test specific logic here; maybe l10n_date helper would too...
  });

  client.helper.emit('timewarp', new Date('Party like it is 1999 and this parses okay!'));

Otherwise each app could handle messing with its own time and making the call to the l10n_date.js helper as it chooses.
Flags: needinfo?(bugmail)
as I said on the [meta] bug (https://bugzilla.mozilla.org/show_bug.cgi?id=984726#c16), I think this kind of test is a bad idea. Specially for an app like calendar where the date affects the layout so much, and also since we will be constantly making incremental improvements to the design.

PS: I was talking with Gareth some time ago about asking the system guys for a way to actually change the clock/date value from inside the marionette tests (specially to test notifications/alarms), similar to `sinon.useFakeTimers()`. Not sure if he created an issue for it already.
Hi Miller,

Got you.
We would not do the reference test for Calendar app.

But we could capture screenshots on an pot-in basis for apps, just like Andrew said. Refer to http://bugzil.la/984726.
Status: ASSIGNED → RESOLVED
Closed: 10 years ago
Resolution: --- → WONTFIX
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: