private static IWebDriver InitOnSaucelabs(string deviceName, string platformVersion, ScreenOrientation deviceOrientation, string testName, string platformName, string browserName) { AppiumOptions options = new AppiumOptions(); options.AddAdditionalCapability(MobileCapabilityType.PlatformName, platformName); options.AddAdditionalCapability(MobileCapabilityType.PlatformVersion, platformVersion); options.AddAdditionalCapability(MobileCapabilityType.DeviceName, deviceName); options.AddAdditionalCapability(MobileCapabilityType.BrowserName, browserName); options.AddAdditionalCapability("deviceOrientation", deviceOrientation.ToString().ToLower()); options.AddAdditionalCapability("username", TestDataProvider.SAUCE_USERNAME); options.AddAdditionalCapability("accesskey", TestDataProvider.SAUCE_ACCESS_KEY); options.AddAdditionalCapability("name", testName); options.AddAdditionalCapability("idleTimeout", 360); options.PlatformName = platformName; IWebDriver webDriver = SeleniumUtils.RetryCreateWebDriver(() => { IWebDriver driver = new RemoteWebDriver(new Uri(TestDataProvider.SAUCE_SELENIUM_URL), options.ToCapabilities(), TimeSpan.FromMinutes(4)); return(driver); }); return(webDriver); }
private void Init_(string testName) { // Initialize the eyes SDK and set your private API key. Eyes eyes = InitEyes_(); string testNameWithArguments = testName; foreach (object argValue in TestContext.CurrentContext.Test.Arguments) { testNameWithArguments += "_" + argValue; } if (eyes.runner_ is VisualGridRunner) { testName += "_VG"; testNameWithArguments += "_VG"; } else if (stitchMode_ == StitchModes.Scroll) { testName += "_Scroll"; testNameWithArguments += "_Scroll"; } TestUtils.SetupLogging(eyes, testNameWithArguments); eyes.Logger.Log("initializing test: {0}", TestContext.CurrentContext.Test.FullName); SpecificTestContextRequirements testContextReqs = new SpecificTestContextRequirements(eyes, testName); testDataByTestId_.Add(TestContext.CurrentContext.Test.ID, testContextReqs); if ((eyes.runner_ is VisualGridRunner && RUNS_ON_CI) || USE_MOCK_VG) { eyes.Logger.Log("using VG mock eyes connector"); string testNameAsFilename = TestUtils.SanitizeForFilename(TestContext.CurrentContext.Test.FullName); testContextReqs.TestNameAsFilename = testNameAsFilename; Assembly thisAssembly = Assembly.GetCallingAssembly(); Stream expectedOutputJsonStream = thisAssembly.GetManifestResourceStream("Test.Eyes.Selenium.DotNet.Resources.VGTests." + testNameAsFilename + ".json"); if (expectedOutputJsonStream != null) { using (StreamReader reader = new StreamReader(expectedOutputJsonStream)) { testContextReqs.ExpectedVGOutput = reader.ReadToEnd(); } eyes.visualGridEyes_.EyesConnectorFactory = new Mock.MockEyesConnectorFactory(); } } else { eyes.Logger.Log("using regular VG eyes connector"); } string seleniumServerUrl = SetupSeleniumServer(testName); bool isWellFormedUri = Uri.IsWellFormedUriString(seleniumServerUrl, UriKind.Absolute); RemoteWebDriver webDriver = SeleniumUtils.RetryCreateWebDriver(() => { RemoteWebDriver driver = null; if (isWellFormedUri) { try { eyes.Logger.Log("Trying to create RemoteWebDriver on {0}", seleniumServerUrl); driver = new RemoteWebDriver(new Uri(seleniumServerUrl), options_.ToCapabilities(), TimeSpan.FromMinutes(4)); } catch (Exception e) { eyes.Logger.Log("Failed creating RemoteWebDriver on {0}. Creating local WebDriver.", seleniumServerUrl); eyes.Logger.Log("Exception: " + e); } } if (driver != null) { return(driver); } if (TestUtils.RUNS_ON_CI) { if (options_.BrowserName.Equals(BrowserNames.Chrome, StringComparison.OrdinalIgnoreCase) || options_.BrowserName.Equals(BrowserNames.Firefox, StringComparison.OrdinalIgnoreCase)) { eyes.Logger.Log("webdriver is null, running on a CI and trying to initialize {0} browser.", options_.BrowserName); driver = (RemoteWebDriver)SeleniumUtils.CreateWebDriver(options_); } } else { eyes.Logger.Log("webdriver is null, running locally and trying to initialize {0}.", options_.BrowserName); driver = (RemoteWebDriver)SeleniumUtils.CreateWebDriver(options_); } return(driver); }); eyes.AddProperty("Selenium Session ID", webDriver.SessionId.ToString()); eyes.AddProperty("ForceFPS", eyes.ForceFullPageScreenshot ? "true" : "false"); eyes.AddProperty("Agent ID", eyes.FullAgentId); //IWebDriver webDriver = new RemoteWebDriver(new Uri("http://localhost:4444/wd/hub"), capabilities_); eyes.Logger.Log("navigating to URL: " + testedPageUrl); IWebDriver driver; try { BeforeOpen(eyes); driver = eyes.Open(webDriver, testSuitName_, testName, testedPageSize); } catch { webDriver.Quit(); throw; } //string userProfile = Environment.GetFolderPath(Environment.SpecialFolder.UserProfile); driver.Navigate().GoToUrl(testedPageUrl); eyes.Logger.Log($"{testName} ({options_.BrowserName}) : {TestDataProvider.BatchInfo.Name}"); testDataByTestId_[TestContext.CurrentContext.Test.ID].WrappedDriver = driver; testDataByTestId_[TestContext.CurrentContext.Test.ID].WebDriver = webDriver; }
private void Init_(string testName) { string testNameWithArguments = InitTestName_(ref testName); ILogHandler logHandler = TestUtils.InitLogHandler(testNameWithArguments); // Initialize the eyes SDK and set your private API key. Eyes eyes = InitEyes_(testName, logHandler); eyes.Logger.Log(TraceLevel.Notice, Stage.TestFramework, StageType.Start, new { TestName = TestContext.CurrentContext.Test.FullName }); string seleniumServerUrl = SetupSeleniumServer(testName); bool isWellFormedUri = Uri.IsWellFormedUriString(seleniumServerUrl, UriKind.Absolute); RemoteWebDriver webDriver = SeleniumUtils.RetryCreateWebDriver(() => { RemoteWebDriver rwDriver = null; if (isWellFormedUri) { try { eyes.Logger.Log(TraceLevel.Info, Stage.TestFramework, StageType.Start, new { message = $"Trying to create RemoteWebDriver on {seleniumServerUrl}" }); rwDriver = new RemoteWebDriver(new Uri(seleniumServerUrl), options_.ToCapabilities(), TimeSpan.FromMinutes(4)); } catch (Exception e) { CommonUtils.LogExceptionStackTrace(eyes.Logger, Stage.TestFramework, StageType.Start, e, testName, seleniumServerUrl); } } if (rwDriver != null) { return(rwDriver); } if (TestUtils.RUNS_ON_CI) { if (options_.BrowserName.Equals(BrowserNames.Chrome, StringComparison.OrdinalIgnoreCase) || options_.BrowserName.Equals(BrowserNames.Firefox, StringComparison.OrdinalIgnoreCase)) { rwDriver = (RemoteWebDriver)SeleniumUtils.CreateWebDriver(options_); } } else { rwDriver = (RemoteWebDriver)SeleniumUtils.CreateWebDriver(options_); } return(rwDriver); }); eyes.AddProperty("Selenium Session ID", webDriver.SessionId.ToString()); eyes.AddProperty("ForceFPS", eyes.ForceFullPageScreenshot ? "true" : "false"); eyes.AddProperty("Agent ID", eyes.FullAgentId); //IWebDriver webDriver = new RemoteWebDriver(new Uri("http://localhost:4444/wd/hub"), capabilities_); IWebDriver driver; try { BeforeOpen(eyes); driver = eyes.Open(webDriver, testSuitName_, testName, testedPageSize); } catch { webDriver.Quit(); throw; } //string userProfile = Environment.GetFolderPath(Environment.SpecialFolder.UserProfile); driver.Navigate().GoToUrl(testedPageUrl); eyes.Logger.Log($"{testName} ({options_.BrowserName}) : {TestDataProvider.BatchInfo.Name}"); testDataByTestId_[TestContext.CurrentContext.Test.ID].WrappedDriver = driver; testDataByTestId_[TestContext.CurrentContext.Test.ID].WebDriver = webDriver; testDataByTestId_[TestContext.CurrentContext.Test.ID].WebDriverProvider.SetDriver(driver); }