Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fluentci-io/tinygo-plugin

Set up your CI/CD Pipeline with a specific version of TinyGo
https://github.com/fluentci-io/tinygo-plugin

continuous-delivery continuous-integration go plugin wasm webassembly

Last synced: about 1 month ago
JSON representation

Set up your CI/CD Pipeline with a specific version of TinyGo

Awesome Lists containing this project

README

        

# TinyGo Plugin

[![fluentci pipeline](https://shield.fluentci.io/x/tinygo)](https://pkg.fluentci.io/tinygo)
[![ci](https://github.com/fluentci-io/tinygo-plugin/actions/workflows/ci.yml/badge.svg)](https://github.com/fluentci-io/tinygo-plugin/actions/workflows/ci.yml)

This plugin sets up your CI/CD pipeline with a specific version of [tinygo](https://tinygo.org/).

## 🚀 Usage

Add the following command to your CI configuration file:

```bash
fluentci run --wasm tinygo setup
```

## Functions

| Name | Description |
| ------ | ------------------------------------------ |
| setup | Installs a specific version of tinygo. |
| build | Compile packages and dependencies |
| run | Compile and run immediately |
| test | Test packages |
| clean | empty cache directory ($HOME/.cache/tinygo) |

## Code Usage

Add `fluentci-pdk` crate to your `Cargo.toml`:

```toml
[dependencies]
fluentci-pdk = "0.1.9"
```

Use the following code to call the plugin:

```rust
use fluentci_pdk::dag;

// ...

dag().call("https://pkg.fluentci.io/[email protected]?wasm=1", "setup", vec!["latest"])?;
```

## 📚 Examples

Github Actions:

```yaml
- name: Setup Fluent CI CLI
uses: fluentci-io/setup-fluentci@v5
with:
wasm: true
plugin: tinygo
args: |
setup
- name: Show tinygo version
run: |
type tinygo
tinygo version
```