Java tutorial
/******************************************************************************* * QMetry Automation Framework provides a powerful and versatile platform to * author * Automated Test Cases in Behavior Driven, Keyword Driven or Code Driven * approach * Copyright 2016 Infostretch Corporation * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or any later version. * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, * DAMAGES OR * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT * OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE * You should have received a copy of the GNU General Public License along with * this program in the name of LICENSE.txt in the root folder of the * distribution. If not, see https://opensource.org/licenses/gpl-3.0.html * See the NOTICE.TXT file in root folder of this source files distribution * for additional information regarding copyright ownership and licenses * of other open source software / files used by QMetry Automation Framework. * For any inquiry or need additional information, please contact * support-qaf@infostretch.com *******************************************************************************/ package com.quantum.listerners; import com.quantum.steps.PerfectoQAFSteps; import com.quantum.utils.CloudUtils; import com.quantum.utils.ConfigurationUtils; import com.quantum.utils.ConsoleUtils; import com.qmetry.qaf.automation.ui.webdriver.CommandTracker; import com.qmetry.qaf.automation.ui.webdriver.QAFExtendedWebDriver; import com.qmetry.qaf.automation.ui.webdriver.QAFWebDriverCommandAdapter; import com.qmetry.qaf.automation.util.StringUtil; import org.openqa.selenium.Capabilities; import org.openqa.selenium.remote.DesiredCapabilities; import org.openqa.selenium.remote.DriverCommand; /** * @author chirag.jayswal (chirag.jayswal@infostretch.com) */ public class PerfectoDriverListener extends QAFWebDriverCommandAdapter { @Override public void beforeCommand(QAFExtendedWebDriver driver, CommandTracker commandTracker) { if (commandTracker.getCommand().equalsIgnoreCase(DriverCommand.QUIT)) { try { String appName = (String) driver.getCapabilities().getCapability("applicationName"); if (StringUtil.isNotBlank(appName) && StringUtil .isBlank((String) driver.getCapabilities().getCapability("eclipseExecutionId"))) { try { PerfectoQAFSteps.closeApplication(appName); } catch (Exception e) { } } driver.close(); } catch (Exception e) { // ignore } } } @Override public void beforeInitialize(Capabilities desiredCapabilities) { if (ConfigurationUtils.getBaseBundle().getString("remote.server", "").contains("perfecto")) { String eclipseExecutionId = ConfigurationUtils.getExecutionIdCapability(); if (StringUtil.isNotBlank(eclipseExecutionId)) { ((DesiredCapabilities) desiredCapabilities).setCapability("eclipseExecutionId", eclipseExecutionId); } } } @Override public void onInitialize(QAFExtendedWebDriver driver) { DesiredCapabilities dcaps = CloudUtils.getDeviceProperties((DesiredCapabilities) driver.getCapabilities()); ConfigurationUtils.setActualDeviceCapabilities(dcaps.asMap()); ConsoleUtils.logWarningBlocks("DEVICE PROPERTIES: " + dcaps.toString()); } }