#!/usr/bin/env python # Copyright (c) 2012 The Chromium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. import logging import os import time import pyauto_functional import pyauto import test_utils class NetflixTestHelper(): """Helper functions for Netflix tests. For sample usage, look at class NetflixTest. """ # Netflix player states. IS_GUEST_MODE_ERROR = '0' IS_PLAYING = '4' TITLE_HOMEPAGE = 'http://movies.netflix.com/WiHome' SIGNOUT_PAGE = 'https://account.netflix.com/Logout' # 30 Rock. VIDEO_URL = 'http://movies.netflix.com/WiPlayer?' + \ 'movieid=70136124&trkid=2361637&t=30+Rock' _pyauto = None def __init__(self, pyauto): self._pyauto = pyauto def _IsNetflixPluginEnabled(self): """Determine Netflix plugin availability and its state.""" return [x for x in self._pyauto.GetPluginsInfo().Plugins() \ if x['name'] == 'Netflix' and x['enabled']] def _LoginToNetflix(self): """Login to Netflix.""" credentials = self._pyauto.GetPrivateInfo()['test_netflix_acct'] board_name = self._pyauto.ChromeOSBoard() assert credentials.get(board_name), \ 'No netflix credentials for %s.' % board_name self._pyauto.NavigateToURL(credentials['login_url']) login_js = """ document.getElementById('email').value='%s'; document.getElementById('password').value='%s'; window.domAutomationController.send('ok'); """ % (credentials[board_name], credentials['password']) self._pyauto.assertEqual(self._pyauto.ExecuteJavascript(login_js), 'ok', msg='Failed to set login credentials.') self._pyauto.assertTrue(self._pyauto.SubmitForm('login-form'), msg='Login to Netflix failed. We think this is an authetication ' 'problem from the Netflix side. Sometimes we also see this while ' 'login in manually.') def _GetVideoDroppedFrames(self, tab_index=0, windex=0): """Returns total Netflix video dropped frames.""" js = """ var frames = nrdp.video.droppedFrames; window.domAutomationController.send(frames + ''); """ return int(self._pyauto.ExecuteJavascript(js, tab_index=tab_index, windex=windex)) def _GetVideoFrames(self, tab_index=0, windex=0): """Returns Netflix video total frames.""" js = """ var frames = nrdp.video.totalFrames; window.domAutomationController.send(frames + ''); """ return int(self._pyauto.ExecuteJavascript(js, tab_index=tab_index, windex=windex)) def _HandleInfobars(self): """Manage infobars that come up during the test.""" def _HandleNetflixInfobar(): tab_info = self._pyauto.GetBrowserInfo()['windows'][0]['tabs'][0] infobars = tab_info['infobars'] index = 0 for infobar in infobars: if 'netflix' in infobar['text']: # After storage infobar pops up, clicking the Ok button immediately # returns the Storage error on faster machines like Stumpy/Lumpy so # adding a delay of 1 second here. time.sleep(1) self._pyauto.PerformActionOnInfobar('accept', infobar_index=index) return True index = index + 1 return False self._pyauto.assertTrue(self._pyauto.WaitUntil(_HandleNetflixInfobar), msg='Netflix infobar did not show up') def CurrentPlaybackTime(self): """Returns the current playback time in seconds.""" time = self._pyauto.ExecuteJavascript(""" time = nrdp.video.currentTime; window.domAutomationController.send(time + ''); """) return int(float(time)) def SignOut(self): """Sign out from Netflix Login.""" self._pyauto.NavigateToURL(self.SIGNOUT_PAGE) def LoginAndStartPlaying(self): """Login and start playing the video.""" self._pyauto.assertTrue(self._pyauto._IsNetflixPluginEnabled(), msg='Netflix plugin is disabled or not available.') self._pyauto._LoginToNetflix() self._pyauto.assertTrue(self._pyauto.WaitUntil( lambda: self._pyauto.GetActiveTabURL().spec(), expect_retval=self.TITLE_HOMEPAGE), msg='Login to Netflix failed.') self._pyauto.NavigateToURL(self.VIDEO_URL) self._pyauto._HandleInfobars() def CheckNetflixPlaying(self, expected_result, error_msg): """Check if Netflix is playing the video or not. Args: expected_result: expected return value from Netflix player. error_msg: If expected value isn't matching, error message to throw. """ self._pyauto.assertTrue(self._pyauto.WaitUntil( lambda: self._pyauto.ExecuteJavascript(""" if (typeof nrdp == 'undefined') { window.domAutomationController.send('not ready'); } player_status = nrdp.video.readyState; window.domAutomationController.send(player_status + ''); """), expect_retval=expected_result), msg=error_msg) class NetflixTest(pyauto.PyUITest, NetflixTestHelper): """Test case for Netflix player.""" def __init__(self, methodName='runTest', **kwargs): pyauto.PyUITest.__init__(self, methodName, **kwargs) NetflixTestHelper.__init__(self, self) def ShouldAutoLogin(self): return False def _Login(self): """Perform login""" credentials = self.GetPrivateInfo()['test_google_account'] self.Login(credentials['username'], credentials['password']) logging.info('Logged in as %s' % credentials['username']) login_info = self.GetLoginInfo() self.assertTrue(login_info['is_logged_in'], msg='Login failed.') self.assertFalse(login_info['is_guest'], msg='Should not be logged in as guest.') def setUp(self): assert os.geteuid() == 0, 'Run test as root since we might need to logout' pyauto.PyUITest.setUp(self) if self.GetLoginInfo()['is_logged_in']: self.Logout() self._Login() def tearDown(self): self.SignOut() pyauto.PyUITest.tearDown(self) def testPlayerLoadsAndPlays(self): """Test that Netflix player loads and plays the title.""" self.LoginAndStartPlaying() self.CheckNetflixPlaying(self.IS_PLAYING, 'Player did not start playing the title.') def testPlaying(self): """Test that title playing progresses.""" self.LoginAndStartPlaying() self.CheckNetflixPlaying(self.IS_PLAYING, 'Player did not start playing the title.') title_length = self.ExecuteJavascript(""" time = nrdp.video.duration; window.domAutomationController.send(time + ''); """) title_length = int(float(title_length)) prev_time = 0 current_time = 0 count = 0 while current_time < title_length: # We want to test playing only for ten seconds. count = count + 1 if count == 10: break current_time = self.CurrentPlaybackTime() self.assertTrue(prev_time <= current_time, msg='Prev playing time %s is greater than current time %s.' % (prev_time, current_time)) prev_time = current_time # play video for some time time.sleep(1) # In case player doesn't start playing at all, above while loop may # still pass. So re-verifying and assuming that player did play something # during last 10 seconds. self.assertTrue(current_time > 0, msg='Netflix player did not start playing.') class NetflixGuestModeTest(pyauto.PyUITest, NetflixTestHelper): """Netflix in guest mode.""" def __init__(self, methodName='runTest', **kwargs): pyauto.PyUITest.__init__(self, methodName, **kwargs) NetflixTestHelper.__init__(self, self) def setUp(self): assert os.geteuid() == 0, 'Run test as root since we might need to logout' pyauto.PyUITest.setUp(self) if self.GetLoginInfo()['is_logged_in']: self.Logout() self.LoginAsGuest() login_info = self.GetLoginInfo() self.assertTrue(login_info['is_logged_in'], msg='Not logged in at all.') self.assertTrue(login_info['is_guest'], msg='Not logged in as guest.') def tearDown(self): self.SignOut() self.Logout() pyauto.PyUITest.tearDown(self) def testGuestMode(self): """Test that Netflix doesn't play in guest mode login.""" self.LoginAndStartPlaying() self.CheckNetflixPlaying( self.IS_GUEST_MODE_ERROR, 'Netflix player did not return a Guest mode error.') self.assertTrue('Guest Mode Unsupported' in self.GetTabContents(), msg='Guest Mode error is not found on the page.') if __name__ == '__main__': pyauto_functional.Main()