extentreports-java icon indicating copy to clipboard operation
extentreports-java copied to clipboard

BASE64 instaed of screen shot location in the report

Open nagu4u2c opened this issue 10 years ago • 23 comments

Hi anshooarora,

Could we use BASE64 instead of the screen shot location in the report, so that there is no dependency on the location of the screen shots placed.

nagu4u2c avatar Nov 20 '15 06:11 nagu4u2c

Its possible. Using the example here: http://dean.edwards.name/my/base64-ie.html

String s = "" + 
    "/////wAAACwAAAAADwAPAAACIISPeQHsrZ5ModrLlN48CXF8m2iQ3Y" +
    "mmKqVlRtW4MLwWACH+H09wdGltaXplZCBieSBVbGVhZCBTbWFydFNhdmVyIQAAOw==";

test.log(LogStatus.INFO, "Embedded Image: " + 
    test.addScreenCapture(s));

anshooarora avatar Nov 20 '15 16:11 anshooarora

Thanks anshooarora.

However when I used BASE64 in the extentreports, I'm unable to open the image after clicking on the image in the report.

When I click on the image in the report. The image does not get displayed.

Thanks in advance

sample report

nagu4u2c avatar Nov 27 '15 04:11 nagu4u2c

Issue has been fixed since 2.40.2.

anshooarora avatar Apr 07 '16 20:04 anshooarora

This is still happening even while using screenshot location/path for version 2.41.2.

devsh4 avatar Nov 15 '16 11:11 devsh4

Hi Anshooarora,

I still see this issue occurring in 2.41.0 (Latest Build - Nuget Packages). When I try to zoom into the screenshot the image doesn't gets displayed and returns an error message too.

Regards, Santosh

shanmukha27 avatar Jan 03 '17 11:01 shanmukha27

I am currently using version 2.41.1 with base64 images, which render in the report as expected. I am evaluating version 3.0.1 and I no longer see this option. Has this feature been removed?

rab2215 avatar Jan 03 '17 16:01 rab2215

My issue is fixed now with the below code:

test.Log(LogStatus.Fail, "Error Snapshot : " + test.AddBase64ScreenCapture(imgFormat));

Regards, Santosh

shanmukha27 avatar Jan 04 '17 06:01 shanmukha27

Hi shanmukha27. I am looking into the AddBase64ScreenCapture method and can't find much on it. What is imgFormat in this scenario? I am trying to pass the base64 as a string

danielsidler avatar Feb 08 '17 20:02 danielsidler

Hi Daniel,

For base64 image the src in the DOM will look like this: <img src=".. starting with "data:image/png;base64," so after convert the image into base64 you may need to concatenate with the text "data:image/png;base64," as show in the below code.

You can refer the below code:

            string imgFormat;
            using (System.Drawing.Image image = System.Drawing.Image.FromFile(screenshotPath))
            {
                using (MemoryStream m = new MemoryStream())
                {
                    string base64String;
                    image.Save(m, image.RawFormat);
                    byte[] imageBytes = m.ToArray();
                    base64String = Convert.ToBase64String(imageBytes);
                    imgFormat = "data:image/png;base64," + base64String;
                }
            }
            test.Log(LogStatus.Fail, "Error Snapshot : " + test.AddBase64ScreenCapture(imgFormat));

Hope this helps..

Regards, Santosh

shanmukha27 avatar Feb 09 '17 02:02 shanmukha27

Thank you, I have it working now, and this was about the only resource I could find! I have one problem remaining. The screenshots are a bit too big, since they were taken of a whole screen. They go off of the edge of the HTML page, and shrinking them would also make the file smaller. Reducing the size by about 25% would make everything fit.

Is there any way to take a smaller base64 screenshot, or shrink the one taken? My current screenshot method and the line calling it:

public static String CaptureScreen(WebDriver driver){
     TakesScreenshot newScreen = (TakesScreenshot) driver;
     String scnShot = newScreen.getScreenshotAs(OutputType.BASE64);
     return "data:image/jpg;base64, " + scnShot ;
}

t.addBase64ScreenShot(ComplexReportFactory.CaptureScreen(getDriver())));

danielsidler avatar Feb 09 '17 19:02 danielsidler

I guess you can use Bitmap to reduce the size of the screenshot. I found some stuff online hope this helps.

https://forums.asp.net/t/1702883.aspx?How+to+reduce+dimension+of+picture+taken+by+C+half+

shanmukha27 avatar Feb 11 '17 03:02 shanmukha27

Hello @anshooarora, I have the same problem when I click on the image in the report. The image does not get displayed. I'm on latest version 3.0.6.

It works in thumbnail and when I choose show picture. IMG Source: <img data-featherlight="" width="10%"> Any help appreciated. capture

Is that file too big maybe?

PePeLM avatar Jul 03 '17 09:07 PePeLM

Hello @PePeLM / @anshooarora I have the same issue (using 3.0.6). In the lightbox, the image is displayed like the screenshot attached By PePeLm. Maybe an issue caused by the jQuery Plugin Featherlight?

taddeuz avatar Jul 07 '17 06:07 taddeuz

@taddeuz I downgraded to v 2.41.2 and I saved as FILE and that works for me. Now I need to integrate this with TestNG listener somehow ...

PePeLM avatar Jul 07 '17 07:07 PePeLM

How the same can be achieved in JAVA? Could someone plz share the code..

abvijay avatar Jul 25 '17 05:07 abvijay

@anshooarora ScreenShot is available in Report but when clicked on it, it is blank. picnotviewed

String scnShot = ((TakesScreenshot) driver).getScreenshotAs(OutputType.BASE64); return "data:image/gif;base64, " + scnShot ;

logger.fail("details", MediaEntityBuilder.createScreenCaptureFromPath(screenshot_path).build());

abvijay avatar Jul 25 '17 09:07 abvijay

Whoever is unable to see the screenshot when you click on thumbnail, can you people try opening it in Chrome browser? Even I faced same issue when I tried using IE, but same file when opened with Chrome displays correctly.

bksooraj avatar Jan 14 '18 10:01 bksooraj

I was able to add this to the report at test level flawlessly in C# and nunit if anyone is interest here it is:

`

        string testName = TestContext.CurrentContext.Test.Name;
        string path = TestContext.CurrentContext.TestDirectory + "\\";
        string fileName = testName + ".png";
        string extentReportImage = Path.Combine(path, fileName);

        ITakesScreenshot screenshotDriver = driver as ITakesScreenshot;
        Screenshot screenshot = screenshotDriver.GetScreenshot();
        screenshot.SaveAsFile(extentReportImage);

        string imgFormat;

        using (Image image = Image.FromFile(extentReportImage))
        {
            using (MemoryStream m = new MemoryStream())
            {
                string base64String;
                image.Save(m, image.RawFormat);
                byte[] imageBytes = m.ToArray();
                base64String = Convert.ToBase64String(imageBytes);
                imgFormat = base64String;
            }
        }

        try
        {
            test.Log(Status.Fail, "Screenshot from failed test step:", MediaEntityBuilder.CreateScreenCaptureFromBase64String(imgFormat).Build());
        }
        catch (IOException e)
        {
            Console.WriteLine("Error in the captureAndDisplayScreenShot method: " + e.Message);
        }
    `

jmatthews79 avatar Mar 05 '18 15:03 jmatthews79

@jmatthews79 is this feature not working at the event/log level?

anshooarora avatar Mar 05 '18 16:03 anshooarora

Hi @abvijay

You can use the below code to capture screenshot, save to the specified location and embed to the report.

Reporter.addScreenCaptureFromPath(CaptureScreen(driver,"FailedScenario"));

public String CaptureScreen(WebDriver driver, String imageName) { File sourceFile = ((TakesScreenshot)driver).getScreenshotAs(OutputType.FILE); String encodedBase64 = null; FileInputStream fileInputStreamReader = null; try { fileInputStreamReader = new FileInputStream(sourceFile); byte[] bytes = new byte[(int)sourceFile.length()]; fileInputStreamReader.read(bytes); encodedBase64 = new String(Base64.encodeBase64(bytes));

        String screenShotDestination = createScreeshotFolderStructure()+"/"+
                imageName.trim().replace(" ","_") + ".png";

        File destination = new File(screenShotDestination);
        FileUtils.copyFile(sourceFile, destination);

    } catch (IOException e) {
        e.printStackTrace();
    }
    return "data:image/png;base64,"+encodedBase64;
}

SwathiNallan avatar Mar 07 '18 00:03 SwathiNallan

@PePeLM, @anshooarora , I am still facing the issue, The image is displayed as thumbnail in the report. But when I zoom it, it shows something like this ,

Can anyone please enlighten?

capture

testergirlash avatar May 29 '18 13:05 testergirlash

I added base64 images to my report and they are showing up as distorted when I open them. I took the string representation of it and entered it into an online decoder and the image displays correctly. Has anyone encountered this. I included screenshots and the version I'm using.

            <dependency>
		<groupId>com.aventstack</groupId>
		<artifactId>extentreports</artifactId>
		<version>3.1.5</version>
	</dependency>

screenshot_3

screenshot_4

beedyb220 avatar Jun 01 '18 23:06 beedyb220

@beedyb220 , try to use version 3.0.7. I had experienced the same issue and since I have rolled back from 3.1.5, it started working. But note: the image size will be large, so you should reduce it before actually embed into your report

Alaray avatar Oct 17 '18 09:10 Alaray