All Downloads are FREE. Search and download functionalities are using the official Maven repository.

co.verisoft.fw.extentreport.ReportManager Maven / Gradle / Ivy

Go to download

VeriSoft framework for testing web and mobile applications. junit 5 Module

There is a newer version: 2.0.4
Show newest version
package co.verisoft.fw.extentreport;

/*
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */


import com.aventstack.extentreports.reporter.ExtentSparkReporter;
import lombok.Getter;
import lombok.ToString;
import lombok.extern.slf4j.Slf4j;
import org.jetbrains.annotations.Nullable;

import java.io.File;
import java.util.HashMap;
import java.util.Map;


/**
 * 

* Extent Report manager. This class is a singletone, and wraps the behavior of ExtentReport.
* ExtentTest is created automatically upon invoking getInstance(); *

* * @author David Yehezkel, refactor by Nir Gallner * @see DelegateExtentReports * @see DelegateExtentTest * @since 1.9.6, updated 0.0.3 (Jan 2022) */ @ToString @Slf4j public final class ReportManager { private static ReportManager instance; static Map tests = new HashMap<>(); @Getter private DelegateExtentReports report; @Getter private static String reportName; private ReportManager(String reportHtmlNameAndPath) { ReportManager.reportName = reportHtmlNameAndPath; report = new DelegateExtentReports(); ExtentSparkReporter esr = new ExtentSparkReporter(reportName); report.attachReporter(esr); } /** * Return the instance of ReportManager. At the first call, it will create an instance. Afterwards, it will follow * the singletone design pattern * * @return ReportManager instance of the manager */ public synchronized static ReportManager getInstance() { if (null == instance) { String directoryName = "Extent-Report"; //Create a directory if does not exist File directory = new File(System.getProperty("user.dir") + "/target/" + directoryName + "/"); if (!directory.exists()) { directory.mkdir(); } reportName = (System.getProperty("user.dir") + "/target/" + directoryName + "/TestReport.html"); // Create new instance of the report manager instance = new ReportManager(reportName); } return instance; } /** * Returns the current test * * @return Current running test, or null */ public synchronized @Nullable DelegateExtentTest getCurrentTest() { return tests.get((int) (Thread.currentThread().getId())); } /** * Creates a new test for the extent report * * @param name test name * @return new test instance */ public synchronized DelegateExtentTest newTest(String name) { DelegateExtentTest test = new DelegateExtentTest(report.createTest(name)); tests.put((int) (Thread.currentThread().getId()), test); return test; } /** * flush the file and creates the report html */ public synchronized void flush() { this.report.flush(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy