• Stars
    star
    582
  • Rank 76,801 (Top 2 %)
  • Language
    Kotlin
  • License
    MIT License
  • Created about 6 years ago
  • Updated 9 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Simple and extensible plugin to track task times in your Gradle Project.

Talaiot

CircleCI codecov

Talaiot is an extensible library targeting teams using the Gradle Build System. It records build/task duration helping to understand problems of the build and detecting bottlenecks. For every record, it will add additional information defined by default or custom metrics.

Talaiot is compatible with different systems like InfluxDb, Elasticsearch or RethinkDb. You need to use a Plugin to work with Talaiot. You can use the standard plugin, including all the functionality, or if you have a specific requirement with a individual plugin.

Current available plugins:

Plugin Description
standard Contains all the available publishers listed below
base Talaiot core functionality with Json, Output and Timeline publishers
elasticsearch Talaiot core functionality with Elasticsearch publisher
graph Talaiot core functionality with Graph publisher
influxdb Talaiot core functionality with Influxdb publisher
influxdb2 Talaiot core functionality with Influxdb2 (Flux) publisher
pushgateway Talaiot core functionality with Pushgateway publisher
rethinkdb Talaiot core functionality with Rethinkdb publisher

Once you have Talaiot integrated you can create dashboards using the build information stored:

What is Talaiot?

"... while some certainly had a defensive purpose, the use of others is not clearly understood. Some believe them to have served the purpose of lookout or signalling towers..."

https://en.wikipedia.org/wiki/Talaiot

Table of Contents

  1. Setup
  2. Snapshots
  3. Talaiot Extension
  4. Samples
  5. Example: Analyzing Data provided by Talaiot
  6. Other Existing Libraries
  7. Articles
  8. Contributing
  9. Contributors
  10. Thanks

Setup

Standard Plugin

Kotlin

Using the plugins DSL:

plugins {
  id("io.github.cdsap.talaiot") version "<latest version>"
}

Using legacy plugin application:

buildscript {
  repositories {
    maven {
      url = uri("https://plugins.gradle.org/m2/")
    }
  }
  dependencies {
    classpath("io.github.cdsap:talaiot:<latest version>")
  }
}

apply(plugin = "io.github.cdsap.talaiot")

Groovy

Using the plugins DSL:

plugins {
  id "io.github.cdsap.talaiot" version "<latest version>"
}

Using legacy plugin application:

buildscript {
  repositories {
    maven {
      url "https://plugins.gradle.org/m2/"
    }
  }
  dependencies {
    classpath "io.github.cdsap:talaiot:<latest version>"
  }
}

apply plugin: "io.github.cdsap.talaiot"

Individual Plugins

Each plugin is deployed to the Gradle Plugin Portal using thee following convention:

Plugin Id
base io.github.cdsap.talaiot.plugin.base
elasticsearch io.github.cdsap.talaiot.plugin.elasticsearch
graph io.github.cdsap.talaiot.plugin.graph
influxdb io.github.cdsap.talaiot.plugin.influxdb
pushgateway io.github.cdsap.talaiot.plugin.pushgateway
rethinkdb io.github.cdsap.talaiot.plugin.rehinkdb

Kotlin Example Plugin

Using the plugins DSL:

plugins {
  id("io.github.cdsap.talaiot.plugin.base") version "<latest version>"
}

Using legacy plugin application:

buildscript {
  repositories {
    maven {
      url = uri("https://plugins.gradle.org/m2/")
    }
  }
  dependencies {
    classpath("io.github.cdsap.talaiot.plugin:base:<latest version>")
  }
}

apply(plugin = "io.github.cdsap.talaiot.plugin.base")

Groovy

Using the plugins DSL:

plugins {
  id "io.github.cdsap.talaiot.plugin.base" version "<latest version>"
}

Using legacy plugin application:

buildscript {
  repositories {
    maven {
      url "https://plugins.gradle.org/m2/"
    }
  }
  dependencies {
    classpath "io.github.cdsap.talaiot.plugin:base:<latest version>"
  }
}

apply plugin: "io.github.cdsap.talaiot.plugin.base"

Snapshots

maven ( url = uri("https://s01.oss.sonatype.org/content/repositories/snapshots/") )

Standard Plugin

classpath("io.github.cdsap:talaiot:<latest version>-SNAPSHOT")

Individual Plugin

classpath("io.github.cdsap.talaiot.plugin:base:<latest version>-SNAPSHOT")

Talaiot Extension

Property Description
logger Mode for logging (Silent,Info)
ignoreWhen Configuration to ignore the execution of Talaiot
generateBuildId Generation of unique identifier for each execution(disabled by default)
publishers Configuration to define where to submit the information of the build
metrics Additional information tracked during the execution of the task
filter Rules to filter the build or the tasks to be reported

Metrics

We can include extra information on the build and task tracked data during the build. This information will be added to the default metrics defined.

talaiot {
    metrics {
        // You can add your own custom Metric objects:
        customMetrics(
            MyCustomMetric(),
            // Including some of the provided metrics, individually.
            HostnameMetric()
        )

        // Or define build or task metrics directly:
        customBuildMetrics(
            "kotlinVersion" to $kotlinVersion,
            "javaVersion" to $javaVersion
        )
        customTaskMetrics(
            "customProperty" to $value
        )
    }
}

Read more about it in the Metrics wiki page.

Filters

For every measurement done, Talaiot can filter the tasks tracked to be published. These filters don't apply to GraphPublishers:

Property Description
tasks Configuration used to filter which tasks we want to exclude and include in the execution
module Configuration used to filter which modules we want to exclude and include in the execution
threshold Configuration used to define time execution ranges to filter tasks to be reported

For every measurement done, Talaiot can completely skip publishing process. These filters affect all publishers:

Property Description
build.success Configuration used to skip publishing based on build success.
build.requestedTasks Configuration used to skip publishing based on what was the requested task.

Example:

 filter {
     tasks {
         excludes = arrayOf("preDebugBuild", "processDebugResources")
     }
     modules {
         excludes = arrayOf(":app")
     }
     threshold {
         minExecutionTime = 10
     }
     build {
         success = true
         requestedTasks {
             includes = arrayOf(":app:assemble.*")
             excludes = arrayOf(":app:generate.*")
         }
     }
 }

IgnoreWhen

Property Description
envName Name of the Property
envValue Value of the Property

We will use IgnoreWhen when we want to ignore publishing the results of the build. One use case is to ignore it when we are building on CI:

talaiot {
    ignoreWhen {
        envName = "CI"
        envValue = "true"
    }
}

Publishers configuration

The Publisher configuration will change depending on the type of plugin you are using. Standard Plugin provides all the different publisher configurations, for example:

talaiot {
    publishers {
        influxDbPublisher {
            dbName = "tracking"
            url = "http://localhost:8086"
            taskMetricName = "task"
            buildMetricName = "build"
        }

    }
    filter {
        threshold {
            minExecutionTime = 10
        }
    }
}

This configuration would be valid for the InfluxDb Plugin.

InfluxDbPublisher

Talaiot will send to the InfluxDb server defined in the configuration the values collected during the execution

Property Description
dbName Name of the database
url Url of the InfluxDb Server
taskMetricName Name of the metric used for specific task in the execution
buildMetricName Name of the metric used for the overall information of the build in the execution
username username which is used to authorize against the influxDB instance (optional)
password password for the username which is used to authorize against the influxDB (optional)
retentionPolicyConfiguration retention policy which is used for writing points
publishBuildMetrics Publish build metrics of the publisher, true by default
publishTaskMetrics Publish tasks metrics of the publisher, true by default
buildTags Collection of BuildMetrics used as tags
taskTags Collection of TaskMetrics used as tags

For complete list of

If you need to include custom metrics as tags, you need to use the type Custom

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.influxdb plugins.

InfluxDb2Publisher

Talaiot will send to the InfluxDb (Flux) server defined in the configuration the values collected during the execution

Property Description
token Influx access token
url Url of the InfluxDb Server
taskMetricName Name of the metric used for specific task in the execution
buildMetricName Name of the metric used for the overall information of the build in the execution
org Organization name
bucket Name of bucket
publishBuildMetrics Publish build metrics of the publisher, true by default
publishTaskMetrics Publish tasks metrics of the publisher, true by default
buildTags Collection of BuildMetrics used as tags
taskTags Collection of TaskMetrics used as tags

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.influxdb2 plugins.

RetentionPolicyConfiguration

Retention Policy (RP) describes how long InfluxDB keeps data, how many copies of the data to store in the cluster, and the time range covered by shard groups. RPs are unique per database and along with the measurement and tag set define a series. Since version 1.0.0 we are including by default RP in all the operations included in the publisher. The RetentionPolicyConfiguration includes:

Property Description
name name of the retentionPolicy(rp). Default rpTalaiot
duration duration of the rp. Default 30d
shardDuration the shardDuration. Default 30m
replicationFactor the replicationFactor of the rp. Default 2
isDefault if the rp is the default rp for the database or not. Default false

Example of custom RP Configuration:

influxDbPublisher {
  dbName = "xxxxxx"
  url = "xxxxxx"
  retentionPolicyConfiguration {
    name = "customRp"
    duration = "4w"
    shardDuration = "30m"
    replicationFactor = 1
    isDefault = true
  }
}

TaskDependencyGraphPublisher

Talaiot will generate the Task Dependency Graph in the specific format specified in the configuration

Property Description
ignoreWhen Configuration to ignore the execution of the publisher
html Export the task dependency graph in Html format with support of vis.js
gexf Export the task dependency graph in gexf format
dot Export the task dependency graph in png format. See Graphviz

This new category of publishers does not require constantly evaluating the builds, that's why there is an extra parameter configuration in the Publisher to ignore the execution unless there is some property enabled. Typical use case is use this publisher and collect the files on CI.

The output will be found "${project.rootDir}/talaiot:

Example:

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.graph plugins.

PushGatewayPublisher

Talaiot will send to the PushGateway server defined in the configuration the values collected during the execution.

Property Description
url Url of the PushGateway Server
taskJobName Name of the job required for the tasks metrics to be exported to Prometheus
buildJobName Name of the job required for the build metrics to be exported to Prometheus
publishBuildMetrics Publish build metrics of the publisher, true by default
publishTaskMetrics Publish tasks metrics of the publisher, true by default

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.pushgateway plugins.

JsonPublisher

Talaiot will Publish the results of the build with a json format .

    publishers {
        jsonPublisher = true

    }

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.base plugins.

TimelinePublisher

Talaiot will create a PNG file with the detailed information in chronological order by task of the execution in the different workers.

    publishers {
        timelinePublisher = true

    }

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.base plugins.

ElasticSearchPublisher

Talaiot will send to the ElasticSearch server defined in the configuration the values collected for tasks and build metrics during the execution in the different workers.

Property Description
url ElasticSearch server
taskIndexName Name for the index used to report tasks metrics
buildIndexName Name for the index used to report build metrics
publishBuildMetrics Publish build metrics of the publisher, true by default
publishTaskMetrics Publish tasks metrics of the publisher, true by default

Example:

    publishers {
        elasticSearchPublisher {
          url = "http://localhost:9200"
          taskIndexName = "task"
          buildIndexName = "build"
        }
    }

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.elasticsearch plugins.

HybridPublisher

This Publisher allows composition over publishers to report tasks and build metrics.

Property Description
taskPublisher Publisher configuration used to publish tasks metrics
buildPublisher Publisher configuration used to publish build metrics

Example:

    publishers {
        hybridPublisher {
            taskPublisher = ElasticSearchPublisherConfiguration().apply {
                url = "http://localhost:9200"
                buildIndexName = "build"
                taskIndexName = "task"
            }

            buildPublisher = InfluxDbPublisherConfiguration().apply {
                dbName = "tracking"
                url = "http://localhost:8086"
                buildMetricName = "build"
                taskMetricName = "task"
            }
        }
    }

In this example we are using InfluxDbPublisher to report build metrics and ElasticSearchPublisher to report task metrics.

Included in: io.github.cdsap.talaiot plugin.

RethinkDbPublisher

Talaiot will send to the RethinkDb server defined in the configuration the values collected during the execution

Property Description
dbName Name of the database
url Url of the RethinkDb Server
taskTableName Name of the table used to track tasks information
buildTableName Name of the table used to track the build information
username username which is used to authorize against the RethinkDb instance (optional)
password password for the username which is used to authorize against the RethinkDb (optional)
publishBuildMetrics Publish build metrics of the publisher, true by default
publishTaskMetrics Publish tasks metrics of the publisher, true by default

Included in: io.github.cdsap.talaiot and io.github.cdsap.talaiot.plugin.rethinkdb plugins.

Custom Publishers

Talaiot allows using custom publishers defined by the requirements of your environment, in case you are using another implementation.

talaiot {
    publishers {
        // You can define one or more custom publishers:
        customPublishers(
            MyCustomPublisher()
        )
    }
}

Read more about it in the Publishers wiki page In you are not using additional plugins we recommend to use io.github.cdsap.talaiot.plugin.base.

Sample

Folder sample contains a Gradle project using Talaiot:

cd sample
./gradlew assemble

The project includes examples creating custom publishers, defining metrics using different publishers.

Example: Analyzing Data provided by Talaiot

Docker, InfluxDb and Grafana

To have a quick setup to see the possibilities of Talaiot we are providing a Docker image to setup a Grafana + InfluxDb instances(based on this great repo).

Additionally, the Docker image is creating a default database, a provisioned dashboard and the default datasource for InfluxDb. The source is here:

To run the Docker Image:

docker run -d \
  -p 3003:3003 \
  -p 3004:8083 \
  -p 8086:8086 \
  -p 22022:22 \
  -v /var/lib/influxdb \
  -v /var/lib/grafana \
  cdsap/talaiot:latest

You can access to the local instance of Grafana:

http://localhost:3003 root/root

Populating data

If you access to the provisioned Dashboards included in the Docker Image(http://localhost:3003/d/F9jppxQiz/android-task-tracking?orgId=1 and http://localhost:3003/d/WlpZEBRMz/task-cache-info?orgId=1), you will see an empty dashboard like:

To see Talaiot in action, you need to populate the data. We are providing a script to populate data based in the sample project included in the repository. You can execute the script:

bash scripts/populate.sh

The script will download the repository and with the help of Gradle Profiler(https://github.com/gradle/gradle-profiler) will trigger number of builds defined in the scenario file:

assemble {
  tasks = ["clean"]
}
clean_build {
  versions = ["5.1"]
  tasks = ["assemble"]
  gradle-args = ["--parallel"]
  cleanup-tasks = ["clean"]
  run-using = cli
  warm-ups = 20
}

Once is finished you can check the results on the Grafana Dashboard http://localhost:3003/d/F9jppxQiz/android-task-tracking?orgId=1:

Additionally, we have included a new Dashboard to show how to work with the Caching information of the task execution:

http://localhost:3003/d/WlpZEBRMz/task-cache-info?orgId=1

Other Existing Libraries

Talaiot is not a new idea. There are multiple awesome plugins to use to achieve same results:

  • Gradle Enterprise: If you are using Gradle Enterprise Talaiot is useless because the aggregation is great and you have the support from Gradle :)

  • Build Time Tracker by Pascal Hartig(@passy).

  • Kuronometer Plugin developed with Scala and FP concepts by Pedro Vicente Gómez Sánchez(@pedrovgs)

Articles

🇹🇭 มาทำความรู้จักกับโปรเจค Android ของเราให้มากขึ้นดีกว่า (part 2) by Kajornsak P.

Metrics Configuration by Svyatoslav Chatchenko

Understanding Talaiot

Exploring the InfluxDbPublisher in Talaiot

Graphs, Gradle and Talaiot

Talaiot at Scale

Contributing

Talaiot is Open Source and accepts contributions of new Publishers, Metrics and Dashboards that we can include as provisioned ones in the Docker image. With the new Plugin structure you can create your own plugins, feel free to contribute with new plugins or if you want to use your own repo drop us comment to include it in a community plugins.

Contributors

Thanks

Pascal Hartig, Build Time Tracker it was an inspiration to build this plugin.

Kohttp Library

Graphviz-java Library

Orchid

More Repositories

1

Bagan

Automate experimentation and collect data on Gradle projects
Kotlin
47
star
2

Kotlin-Client-Server

Example using Kotlin in App Engine and Android
Kotlin
35
star
3

InfoKotlinProcess

Include Kotlin process information in Build Scans or build output
Kotlin
30
star
4

TestRobolectric4

Kotlin
18
star
5

ExamplesPresentationIO

examples of the presentation. Build Bigger, Better: Gradle for Large Projects
Kotlin
14
star
6

GDGDublinWorkshop

Repository for the Workshop on GDG Dublin 24/02/2015
Java
8
star
7

GEApiData

Intermediate layer for GE API
Kotlin
5
star
8

InfoTestProcess

Retrieve information of the Test process in your Build Scan
Kotlin
5
star
9

Workshop_Indonesia

Kotlin
4
star
10

InfoGradleProcess

Include Gradle process information in Build Scans or build output
Kotlin
4
star
11

IpInfo

Kotlin
3
star
12

MyMap

Barcelona Mobile Apps- MyMap
Java
2
star
13

AcmeSettingsGradlePlugin

This project shows how to encapsulate Gradle Enterprise build logic in a Gradle Settings Plugin
Kotlin
2
star
14

HelloWorldAppEngine

Kotlin
2
star
15

MyPosition

Barcelona Mobile Apps- MyPosition
Java
2
star
16

myCamera

Barcelona Mobile Apps- MyCamera
2
star
17

ProjectReport

Kotlin
2
star
18

MyActionBarSherlock

Barcelona Mobile Apps- MyActionBarSherlock
Java
2
star
19

Gradle7.6Issue

Groovy
2
star
20

MyActionBar

Barcelona Mobile Apps- MyActionBar
Java
2
star
21

Agp3.6.0-beta01

1
star
22

CircleCiBuildCacheExample

Kotlin
1
star
23

PaparazziTestDistributionExtension

Kotlin
1
star
24

TestAGP3.6-beta01

1
star
25

HiltDatabindingIssue

Kotlin
1
star
26

GradleEnterpriseApiReports

Kotlin
1
star
27

ProjectGenerator

Kotlin
1
star
28

ConfigurationCacheCustomValueHit

Kotlin
1
star
29

test-typesafeaccessors

Kotlin
1
star
30

ExampleAndroidTestSupportReport

Kotlin
1
star
31

Simple-Scala-Android

Simple Scala example
Scala
1
star
32

ExampleAppMarathon

Kotlin
1
star
33

ProtoExample

1
star
34

simple-plugin

Kotlin
1
star
35

myWidget

Barcelona Mobile Apps- MyWidget
Java
1
star
36

FinalCodeCodeLabTesting

Final code from Codelab https://codelabs.developers.google.com/codelabs/android-testing/index.html
Java
1
star
37

OSSRH-67893

1
star
38

TalaiotClientExample

Sample Project used to provide data to Talaiot Project https://github.com/cdsap/Talaiot
Kotlin
1
star
39

AGP-7.4.0-alpha09-issue

Kotlin
1
star
40

SimpleKtorClientRequest

Kotlin
1
star
41

MergeQueueTests

Kotlin
1
star
42

type-safe-accessors-without-project-name

Reproduces the caching issue when you enable TYPESAFE_PROJECT_ACCESSORS in a project without rootProject.name
Kotlin
1
star
43

TaskReport

Kotlin
1
star
44

TestUsingDifferentSourceProvider

Kotlin
1
star