From 6efd9068234c932b7fca2d64c76e3a76aa0b5edc Mon Sep 17 00:00:00 2001 From: Sam Costa Date: Fri, 2 Jul 2021 07:31:40 +0100 Subject: [PATCH 1/2] Support passing `runInstrumentation` flag as gradle argument (#237) * Support passing `runInstrumentation` flag as gradle argument Will allow overriding the configuration set in the gradle file with the commandline argument. e.g ./gradlew executeScreenshotTests -PrunInstrumentation=false * Run formatting command Co-authored-by: Sam --- .../main/scala/com/karumi/shot/ShotPlugin.scala | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/shot/src/main/scala/com/karumi/shot/ShotPlugin.scala b/shot/src/main/scala/com/karumi/shot/ShotPlugin.scala index 749025c7..6256ed07 100644 --- a/shot/src/main/scala/com/karumi/shot/ShotPlugin.scala +++ b/shot/src/main/scala/com/karumi/shot/ShotPlugin.scala @@ -25,6 +25,7 @@ import org.gradle.api.artifacts.DependencySet import org.gradle.api.tasks.TaskProvider import org.gradle.api.{Plugin, Project} +import scala.util.Try class ShotPlugin extends Plugin[Project] { private val console = new Console @@ -182,7 +183,7 @@ class ShotPlugin extends Plugin[Project] { task.appId = appId } - if (extension.runInstrumentation) { + if (runInstrumentation(project, extension)) { executeScreenshot.configure { task => task.dependsOn(instrumentationTaskName) task.dependsOn(downloadScreenshots) @@ -219,6 +220,20 @@ class ShotPlugin extends Plugin[Project] { } } + private def runInstrumentation(project: Project, extension: ShotExtension): Boolean = { + val property = project.findProperty("runInstrumentation").asInstanceOf[String] + + if (property != null) { + if (Try(property.toBoolean).getOrElse(null) == null) { + throw ShotException("runInstrumentation value must be true|false") + } + + return property.toBoolean + } + + extension.runInstrumentation + } + private def isAnAndroidLibrary(project: Project): Boolean = try { getAndroidLibraryExtension(project) From c9ee88a6c7121c746af1ac860000df382e12537c Mon Sep 17 00:00:00 2001 From: Michael Bailey <1195562+yogurtearl@users.noreply.github.com> Date: Sun, 4 Jul 2021 23:53:04 -0700 Subject: [PATCH 2/2] Remove freemarker. (#238) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Can just use Scala string interpolation instead of freemarker. Fixes https://github.com/Karumi/Shot/issues/231 * Format code Co-authored-by: Pedro Gómez --- core/build.gradle | 1 - .../shot/reports/ExecutionReporter.scala | 62 +++++++------------ .../shot/templates/RecordIndexTemplate.scala} | 21 +++++-- .../VerificationIndexTemplate.scala} | 24 +++++-- 4 files changed, 60 insertions(+), 48 deletions(-) rename core/src/main/{resources/templates/recordIndex.ftl => scala/com/karumi/shot/templates/RecordIndexTemplate.scala} (89%) rename core/src/main/{resources/templates/verificationIndex.ftl => scala/com/karumi/shot/templates/VerificationIndexTemplate.scala} (88%) diff --git a/core/build.gradle b/core/build.gradle index 1119bfdb..be13a761 100644 --- a/core/build.gradle +++ b/core/build.gradle @@ -14,7 +14,6 @@ dependencies { implementation 'org.scala-lang:scala-library:2.12.13' implementation 'org.scala-lang.modules:scala-xml_2.12:1.3.0' implementation 'com.sksamuel.scrimage:scrimage-core_2.12:2.1.8' - implementation 'org.freemarker:freemarker:2.3.31' implementation 'io.github.bitstorm:tinyzip-core:1.0.0' implementation 'org.json4s:json4s-native_2.12:3.6.11' implementation 'org.json4s:json4s-jackson_2.12:3.6.11' diff --git a/core/src/main/scala/com/karumi/shot/reports/ExecutionReporter.scala b/core/src/main/scala/com/karumi/shot/reports/ExecutionReporter.scala index 038f0472..31097f9e 100644 --- a/core/src/main/scala/com/karumi/shot/reports/ExecutionReporter.scala +++ b/core/src/main/scala/com/karumi/shot/reports/ExecutionReporter.scala @@ -1,24 +1,14 @@ package com.karumi.shot.reports import java.io.{File, FileWriter} -import java.util -import scala.collection.JavaConverters._ -import org.apache.commons.io.FileUtils import com.karumi.shot.domain._ import com.karumi.shot.domain.model.{AppId, Folder, ScreenshotComparisionErrors, ScreenshotsSuite} -import freemarker.template.{Configuration, Template, TemplateExceptionHandler} +import com.karumi.shot.templates.RecordIndexTemplate.recordIndexTemplate +import com.karumi.shot.templates.VerificationIndexTemplate.verificationIndexTemplate class ExecutionReporter { - private val freeMarkerConfig: Configuration = { - val config = new Configuration(Configuration.VERSION_2_3_23) - config.setClassForTemplateLoading(getClass, "/templates/") - config.setDefaultEncoding("UTF-8") - config.setTemplateExceptionHandler(TemplateExceptionHandler.RETHROW_HANDLER) - config - } - def generateRecordReport( appId: AppId, screenshots: ScreenshotsSuite, @@ -26,11 +16,10 @@ class ExecutionReporter { flavor: String, buildType: String ) = { - val input = generateRecordTemplateValues(appId, screenshots) - val template = freeMarkerConfig.getTemplate("recordIndex.ftl") + val reportFileContents = populateRecordTemplate(appId, screenshots) resetVerificationReport(flavor, buildType) val reportFolder = buildFolder + Config.recordingReportFolder(flavor, buildType) + "/" - writeReport(buildFolder, input, template, reportFolder) + writeReport(reportFileContents, reportFolder) } def generateVerificationReport( @@ -41,24 +30,21 @@ class ExecutionReporter { buildType: String, showOnlyFailingTestsInReports: Boolean = false ) = { - val input = - generateVerificationTemplateValues(appId, comparision, showOnlyFailingTestsInReports) - val template = freeMarkerConfig.getTemplate("verificationIndex.ftl") + val reportFileContents = + populateVerificationTemplate(appId, comparision, showOnlyFailingTestsInReports) resetVerificationReport(flavor, buildType) val reportFolder = buildFolder + Config.verificationReportFolder(flavor, buildType) + "/" - writeReport(buildFolder, input, template, reportFolder) + writeReport(reportFileContents, reportFolder) } private def writeReport( - buildFolder: Folder, - input: util.Map[String, String], - template: Template, + fileContents: String, reportFolder: String ) = { val indexFile = new File(reportFolder + "index.html") new File(reportFolder).mkdirs() val writer = new FileWriter(indexFile) - template.process(input, writer) + writer.write(fileContents) writer.close() } @@ -69,20 +55,20 @@ class ExecutionReporter { } } - private def generateRecordTemplateValues( + private def populateRecordTemplate( appId: AppId, screenshots: ScreenshotsSuite - ): util.Map[String, String] = { + ): String = { val title = s"Record results: $appId" val numberOfTests = screenshots.size val summaryResults = s"$numberOfTests screenshot tests recorded." val summaryTableBody = generateRecordSummaryTableBody(screenshots) - Map( - "title" -> title, - "summaryResult" -> summaryResults, - "summaryTableBody" -> summaryTableBody - ).asJava + recordIndexTemplate( + title = title, + summaryResult = summaryResults, + summaryTableBody = summaryTableBody + ) } private def generateRecordSummaryTableBody(screenshots: ScreenshotsSuite): String = { @@ -101,11 +87,11 @@ class ExecutionReporter { .mkString("\n") } - private def generateVerificationTemplateValues( + private def populateVerificationTemplate( appId: AppId, comparision: ScreenshotsComparisionResult, showOnlyFailingTestsInReports: Boolean - ): util.Map[String, String] = { + ): String = { val title = s"Verification results: $appId" val screenshots = comparision.screenshots val numberOfTests = screenshots.size @@ -117,12 +103,12 @@ class ExecutionReporter { generateVerificationSummaryTableBody(comparision, showOnlyFailingTestsInReports) val screenshotsTableBody = generateScreenshotsTableBody(comparision, showOnlyFailingTestsInReports) - Map( - "title" -> title, - "summaryResult" -> summaryResults, - "summaryTableBody" -> summaryTableBody, - "screenshotsTableBody" -> screenshotsTableBody - ).asJava + verificationIndexTemplate( + title = title, + summaryResult = summaryResults, + summaryTableBody = summaryTableBody, + screenshotsTableBody = screenshotsTableBody + ) } private def getSortedByResultScreenshots(comparison: ScreenshotsComparisionResult) = diff --git a/core/src/main/resources/templates/recordIndex.ftl b/core/src/main/scala/com/karumi/shot/templates/RecordIndexTemplate.scala similarity index 89% rename from core/src/main/resources/templates/recordIndex.ftl rename to core/src/main/scala/com/karumi/shot/templates/RecordIndexTemplate.scala index 9e10d1ca..58d601cf 100644 --- a/core/src/main/resources/templates/recordIndex.ftl +++ b/core/src/main/scala/com/karumi/shot/templates/RecordIndexTemplate.scala @@ -1,3 +1,13 @@ +package com.karumi.shot.templates + +object RecordIndexTemplate { + def recordIndexTemplate( + title: String, + summaryResult: String, + summaryTableBody: String + ): String = { + // language=HTML + s""" @@ -19,7 +29,7 @@