Skip to content

Commit

Permalink
feat!: add build logic and refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
manuandru committed Mar 15, 2024
1 parent 874d102 commit e9673d7
Show file tree
Hide file tree
Showing 9 changed files with 245 additions and 148 deletions.
163 changes: 83 additions & 80 deletions .github/workflows/build-and-deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,84 +14,87 @@ jobs:
group: build-${{ github.workflow }}-${{ matrix.os }}-${{ github.event.number || github.ref }}
cancel-in-progress: true
steps:
- name: Checkout
uses: DanySK/[email protected]
- uses: DanySK/[email protected]
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
with:
# Dry-deployment
check-command: ./gradlew build --parallel
deploy-command: >-
./gradlew
uploadKotlinOSSRHToMavenCentralNexus
uploadPluginMavenToMavenCentralNexus
uploadPluginMarkerMavenToMavenCentralNexus
close
drop
--parallel
should-run-codecov: ${{ runner.os == 'Linux' }}
should-deploy: >-
${{
runner.os == 'Linux'
&& !github.event.repository.fork
&& github.event_name != 'pull_request'
}}
maven-central-username: ${{ secrets.MAVEN_CENTRAL_USERNAME }}
maven-central-password: ${{ secrets.MAVEN_CENTRAL_PASSWORD }}
signing-key: ${{ secrets.SIGNING_KEY }}
signing-password: ${{ secrets.SIGNING_PASSWORD }}
release:
permissions:
contents: write
packages: write
concurrency:
# Only one release job at a time. Strictly sequential.
group: release
needs:
- build
runs-on: ubuntu-22.04
if: >-
!github.event.repository.fork
&& github.event_name != 'pull_request'
steps:
- name: Checkout
uses: actions/[email protected]
# - name: Checkout
# uses: DanySK/[email protected]
- name: install npm on windows
if: ${{ matrix.os == 'windows-2022' }}
run: |
./gradlew build --parallel
# env:
# CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
# with:
# token: ${{ secrets.DEPLOYMENT_TOKEN }}
- name: Find the version of Node from package.json
id: node-version
run: echo "version=$(jq -r .engines.node package.json)" >> $GITHUB_OUTPUT
- name: Install Node
uses: actions/[email protected]
with:
node-version: ${{ steps.node-version.outputs.version }}
- uses: DanySK/[email protected]
with:
build-command: true
check-command: true
deploy-command: |
npm install
npx semantic-release
should-run-codecov: false
should-deploy: true
github-token: ${{ github.token }}
gradle-publish-secret: ${{ secrets.GRADLE_PUBLISH_SECRET }}
gradle-publish-key: ${{ secrets.GRADLE_PUBLISH_KEY }}
maven-central-username: ${{ secrets.MAVEN_CENTRAL_USERNAME }}
maven-central-password: ${{ secrets.MAVEN_CENTRAL_PASSWORD }}
signing-key: ${{ secrets.SIGNING_KEY }}
signing-password: ${{ secrets.SIGNING_PASSWORD }}
success:
runs-on: ubuntu-22.04
needs:
- release
- build
if: >-
always() && (
contains(join(needs.*.result, ','), 'failure')
|| !contains(join(needs.*.result, ','), 'cancelled')
)
steps:
- name: Verify that there were no failures
run: ${{ !contains(join(needs.*.result, ','), 'failure') }}
## Dry-deployment
# check-command: ./gradlew build --parallel
# deploy-command: >-
# ./gradlew
# uploadKotlinOSSRHToMavenCentralNexus
# uploadPluginMavenToMavenCentralNexus
# uploadPluginMarkerMavenToMavenCentralNexus
# close
# drop
# --parallel
# should-run-codecov: ${{ runner.os == 'Linux' }}
# should-deploy: >-
# ${{
# runner.os == 'Linux'
# && !github.event.repository.fork
# && github.event_name != 'pull_request'
# }}
# maven-central-username: ${{ secrets.MAVEN_CENTRAL_USERNAME }}
# maven-central-password: ${{ secrets.MAVEN_CENTRAL_PASSWORD }}
# signing-key: ${{ secrets.SIGNING_KEY }}
# signing-password: ${{ secrets.SIGNING_PASSWORD }}
# release:
# permissions:
# contents: write
# packages: write
# concurrency:
# # Only one release job at a time. Strictly sequential.
# group: release
# needs:
# - build
# runs-on: ubuntu-22.04
# if: >-
# !github.event.repository.fork
# && github.event_name != 'pull_request'
# steps:
# - name: Checkout
# uses: actions/[email protected]
## with:
## token: ${{ secrets.DEPLOYMENT_TOKEN }}
# - name: Find the version of Node from package.json
# id: node-version
# run: echo "version=$(jq -r .engines.node package.json)" >> $GITHUB_OUTPUT
# - name: Install Node
# uses: actions/[email protected]
# with:
# node-version: ${{ steps.node-version.outputs.version }}
# - uses: DanySK/[email protected]
# with:
# build-command: true
# check-command: true
# deploy-command: |
# npm install
# npx semantic-release
# should-run-codecov: false
# should-deploy: true
# github-token: ${{ github.token }}
# gradle-publish-secret: ${{ secrets.GRADLE_PUBLISH_SECRET }}
# gradle-publish-key: ${{ secrets.GRADLE_PUBLISH_KEY }}
# maven-central-username: ${{ secrets.MAVEN_CENTRAL_USERNAME }}
# maven-central-password: ${{ secrets.MAVEN_CENTRAL_PASSWORD }}
# signing-key: ${{ secrets.SIGNING_KEY }}
# signing-password: ${{ secrets.SIGNING_PASSWORD }}
# success:
# runs-on: ubuntu-22.04
# needs:
# - release
# - build
# if: >-
# always() && (
# contains(join(needs.*.result, ','), 'failure')
# || !contains(join(needs.*.result, ','), 'cancelled')
# )
# steps:
# - name: Verify that there were no failures
# run: ${{ !contains(join(needs.*.result, ','), 'failure') }}
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
package io.github.zuccherosintattico.gradle

import com.lordcodes.turtle.shellRun
import io.github.zuccherosintattico.utils.NodeCommandsExtension.nodeVersion
import org.gradle.api.DefaultTask
import org.gradle.api.tasks.TaskAction

Expand All @@ -17,11 +19,8 @@ open class CheckNodeTask : DefaultTask() {
*/
@TaskAction
fun checkNode() {
val res = Runtime.getRuntime().runCatching { exec("node --version").waitFor() }
if (res.isSuccess) {
logger.quiet("Node is installed")
} else {
logger.error("Node is not installed")
}
runCatching { shellRun { nodeVersion() } }
.onSuccess { logger.quiet("Node is installed at version $it") }
.onFailure { logger.error("Node is not installed") }
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package io.github.zuccherosintattico.gradle

import com.lordcodes.turtle.shellRun
import io.github.zuccherosintattico.utils.NpmCommandsExtension.npmInstall
import org.gradle.api.DefaultTask
import org.gradle.api.tasks.TaskAction

/**
* A task to install NPM dependencies.
*/
open class NpmDependenciesTask : DefaultTask() {
init {
group = "Node"
description = "Install NPM dependencies"
}

/**
The action to install NPM dependencies.
*/
@TaskAction
fun installNpmDependencies() {
logger.quiet("Installing NPM dependencies")
val out = shellRun(project.projectDir) { npmInstall() }
logger.quiet(out)
}
}
64 changes: 11 additions & 53 deletions src/main/kotlin/io/github/zuccherosintattico/gradle/Typescript.kt
Original file line number Diff line number Diff line change
@@ -1,72 +1,30 @@
package io.github.zuccherosintattico.gradle

import org.gradle.api.DefaultTask
import org.gradle.api.Plugin
import org.gradle.api.Project
import org.gradle.api.model.ObjectFactory
import org.gradle.api.provider.Property
import org.gradle.api.provider.Provider
import org.gradle.api.tasks.Input
import org.gradle.api.tasks.Internal
import org.gradle.api.tasks.TaskAction
import org.gradle.api.Task
import org.gradle.kotlin.dsl.create
import org.gradle.kotlin.dsl.property
import org.gradle.kotlin.dsl.register
import java.io.Serializable

/**
* Just a template.
* A plugin to compile TypeScript files.
*/
open class Typescript : Plugin<Project> {
override fun apply(project: Project) {
val extension = project.extensions.create<TypescriptExtension>("typescript")

val checkNodeTask = project.tasks.register<CheckNodeTask>("checkNode")

project.tasks.register<TypescriptTask>("compileTypescript") {
val checkNodeTask = project.registerTask<CheckNodeTask>("checkNode")
val npmDependenciesTask = project.registerTask<NpmDependenciesTask>("npmDependencies") {
dependsOn(checkNodeTask)
sourceSet.set(extension.sourceSet)
}
project.registerTask<TypescriptTask>("compileTypescript") {
dependsOn(npmDependenciesTask)
entrypoint.set(extension.entrypoint)
buildDir.set(extension.outputDir)
}
}
}

/**
* Just a template.
*/
open class TypescriptTask : DefaultTask() {

/**
* Just a template.
*/
@Input
val sourceSet: Property<String> = project.objects.property()

/**
* Read-only property calculated from the greeting.
*/
@Internal
val message: Provider<String> = sourceSet.map { "Hello from $it" }

/**
* Just a template.
*/
@TaskAction
fun printMessage() {
logger.quiet(message.get())
}
}

/**
* Just a template.
*/
open class TypescriptExtension(objects: ObjectFactory) : Serializable {

/**
* Just a template.
*/
val sourceSet: Property<String> = objects.property<String>().convention("src/main/typescript")

companion object {
private const val serialVersionUID = 1L
private inline fun <reified T : Task> Project.registerTask(name: String, noinline action: T.() -> Unit = {}) =
tasks.register<T>(name, action)
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
package io.github.zuccherosintattico.gradle

import org.gradle.api.model.ObjectFactory
import org.gradle.api.provider.Property
import org.gradle.kotlin.dsl.property
import java.io.Serializable

/**
* The extension for configuring TypeScript plugin.
*/
open class TypescriptExtension(objects: ObjectFactory) : Serializable {

/**
* The path to the TypeScript source set.
*/
val entrypoint: Property<String> = objects.propertyWithDefault("src/main/typescript/index.ts")

/**
* The path to the TypeScript output directory.
*/
val outputDir: Property<String> = objects.propertyWithDefault("build/dist")

companion object {
private const val serialVersionUID = 1L

private inline fun <reified T> ObjectFactory.propertyWithDefault(value: T): Property<T> =
property<T>().convention(value)
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package io.github.zuccherosintattico.gradle

import com.lordcodes.turtle.shellRun
import io.github.zuccherosintattico.utils.NpmCommandsExtension.npxCommand
import org.gradle.api.DefaultTask
import org.gradle.api.provider.Property
import org.gradle.api.tasks.Input
import org.gradle.api.tasks.OutputFile
import org.gradle.api.tasks.TaskAction

/**
* Typescript task.
*/
abstract class TypescriptTask : DefaultTask() {

/**
* The source set to compile.
*/
@get:Input
abstract val entrypoint: Property<String>

/**
* The build directory.
*/
@get:OutputFile
abstract val buildDir: Property<String>

/**
* The task action.
*/
@TaskAction
fun compileTypescript() {
logger.quiet("Compiling TypeScript files in ${entrypoint.get()}")
shellRun(project.projectDir) {
npxCommand("tsc", "--outDir", buildDir.get(), entrypoint.get())
}.also { logger.quiet("Compiled: $it") }
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package io.github.zuccherosintattico.utils

import com.lordcodes.turtle.ShellScript

/**
* The extension for Node commands for [ShellScript].
*/
object NodeCommandsExtension {

/**
* Get the version of installed Node.
*/
fun ShellScript.nodeVersion(): String = nodeCommand(listOf("--version"))

private fun ShellScript.nodeCommand(arguments: List<String>): String = command("node", arguments)
}
Loading

0 comments on commit e9673d7

Please sign in to comment.