Projektor



This Gradle plugin supports automatically gathering and publishingthe XML test results to the Projektor server. Iexplorer for mac free download. It listens to theend of the build, gathers up all the XML results generated byTest tasks in the build, then sends those to the Projektor server.

Projektor

Example Projektor report from the plugin’s build: https://projektorlive.herokuapp.com/tests/8VQSLOBCSCWA

Use plugin

Get the latest projectors and projector screens for larger-than-life presentations, movies & video gaming action at Best Buy. BenQ is the #1 DLP Projector manufacturer globally. BenQ Projectors for home to office.

To apply this plugin to your project:

See https://plugins.gradle.org/plugin/dev.projektor.publish for the latest version.

By default the plugin publishes results from all Test tasks in the projectwhen the build finishes.

The plugin also adds a publishResults task that lets you publish testresults from a build after it has executed (for example, if you didn’t have auto-publish on)This can be a good way to easily share a specific test failure with colleagues.

./gradlew publishResults

Note: If you have a multi-project build, please apply the plugin to the root project.

Configuration

All the configuration of the plugin is inside the projektor block.To use the plugin, first set the URL of the Projektor server:

You can also include results from arbitrary directories in your build with the additionalResultsDirs configuration option:

Resiliency

The plugin includes configurable retry and timeout settings to help make publishing resultsto the Projektor server more resilient against network hiccups:

ProjektoritProjektor

Slack message

It can be helpful to proactively notify folks when a CI build fails via Slack.To help make that easier, the Projektor Gradle plugin has the option to write a formatted Slackmessage in a JSON file. This Slack message includes a direct link to the Projektor test reportso users can quickly investigate test failures.

To use it, set the writeSlackMessageFile parameter to true.

By default, the Slack message is written to a file named projektor_failure_message.json,but you can specify your own file name by setting slackMessageFileName Stranded deep free download mac 2017.

Code coverage

Starting with plugin version 5.5.4 and server 3.5.1, Projektor has the ability to publish andvisualize code coverage data as part of the Projektor report.

To include code coverage stats in your Projektor reports, first ensure you are using plugin version 5.5.4 or higher,enable Jacoco in your build,and include the jacocoTestReport task with your build. That’s it.The Projektor Gradle plugin will automatically configure, collect and upload the XML coverage reports fromeach project in the build that uses Jacoco.

For an example Projektor report with coverage, check out https://projektorlive.herokuapp.com/tests/SUWSHGIRS6JP/coverage

Ironically, this example build shows that the code coverage of the coverage parsing module in Projektor is low. Need to work on that.

Update: Coverage for the parsing module looking better now: https://projektorlive.herokuapp.com/tests/0M7BEOCS9VJA/coverage

Combining code coverage from multiple test tasks

Some projects have separate test tasks, such as test and integrationTest.Projektor will automatically collect coverage stats for all projects in a multi-project build,but if your project has multiple test tasks in the same project you’ll need a bit of extra configurationin your build.gradle file to have Jacoco combine the coverage data from the different test tasksbefore the coverage data is sent to the Projektor server:

All configuration options

ParameterTypeDefaultDescription
serverUrl**StringnullProjektor server URL to publish results to
alwaysPublishInCIbooleantrueWhether results are automatically published at the end of the build when running in CI
publishOnLocalFailurebooleantrueWhether results are automatically published at the end of the build if it fails when running locally
alwaysPublishbooleanfalseWhether to always publish the results regardless of environment or outcome
publishTokenStringnullToken to include in publish request to server (only needed when server has publish token set)
additionalResultsDirsList<String>[]Additional directories to include results from. Useful when you want to include results from a task that isn’t Test type
attachmentsList<FileTree>[]FileTrees to include as attachments to the test report and make available in the UI
compressionEnabledbooleantrueWhether to compress the test results with GZIP when sending them to the server
publishRetryMaxAttemptsint3Max number of attempts when retrying publish of results to server
publishRetryIntervallong100Amount to wait (in milliseconds) between retry attempts
publishTimeoutlong10_000Timeout (in milliseconds) to send results to the server
writeSlackMessageFilebooleanfalseWhether to write a Slack message file with a link to the Projektor test report
slackMessageFileNameStringprojektor_failure_message.jsonName of the Slack message file (if enabled)
codeCoveragePublishbooleantrueWhether to include code coverage data in the Projektor report (if the build has coverage enabled with the Jacoco plugin)

Proyector

** Required

Compatibility

Plugin versionServer versionJava version
1.0.0 - 1.0.21.0.0+8+
1.0.31.0.6+8+
2.0.02.0.0+8+
3.0.02.0.0+8+
4.0.02.0.0+11+
5.0.0+3.3.0+11+
5.1.0+3.5.0+11+

Configure and apply via another plugin

In larger organizations it can be common to have base plugins that apply and configure a common setof plugins used by each project. To apply the ProjektorPublishPlugin this way from another plugin:

Google uses cookies and data to:
  • Deliver and maintain services, like tracking outages and protecting against spam, fraud, and abuse
  • Measure audience engagement and site statistics to understand how our services are used

Proyectores

If you agree, we’ll also use cookies and data to:
  • Improve the quality of our services and develop new ones
  • Deliver and measure the effectiveness of ads
  • Show personalized content, depending on your settings
  • Show personalized or generic ads, depending on your settings, on Google and across the web
For non-personalized content and ads, what you see may be influenced by things like the content you’re currently viewing and your location (ad serving is based on general location). Personalized content and ads can be based on those things and your activity like Google searches and videos you watch on YouTube. Personalized content and ads include things like more relevant results and recommendations, a customized YouTube homepage, and ads that are tailored to your interests.

Click “Customize” to review options, including controls to reject the use of cookies for personalization and information about browser-level controls to reject some or all cookies for other uses. You can also visit g.co/privacytools anytime.