Kotlin Help

Get started with Kotlin/Wasm and WASI

This tutorial demonstrates how to run a simple Kotlin/Wasm application using the WebAssembly System Interface (WASI) in various WebAssembly virtual machines.

You can find examples of an application running on Node.js, Deno, and WasmEdge virtual machines. The output is a simple application that uses the standard WASI API.

Currently, Kotlin/Wasm supports WASI 0.1, also known as Preview 1. Support for WASI 0.2 is planned for future releases.

Before you start

  1. Download and install the latest version of IntelliJ IDEA.

  2. Clone the Kotlin/Wasm WASI template repository by selecting File | New | Project from Version Control in IntelliJ IDEA.

    You can also clone it from the command line:

    git clone git@github.com:Kotlin/kotlin-wasm-wasi-template.git

Run the application

  1. Open the Gradle tool window by selecting View | Tool Windows | Gradle.

    In the Gradle tool window, you can find the Gradle tasks under kotlin-wasm-wasi-example once the project loads.

  2. From kotlin-wasm-wasi-example | Tasks | kotlin node, select and run one of the following Gradle tasks:

    • wasmWasiNodeRun to run the application in Node.js.

    • wasmWasiDenoRun to run the application in Deno.

    • wasmWasiWasmEdgeRun to run the application in WasmEdge.

    Kotlin/Wasm and WASI tasks

Alternatively, run one of the following commands in the terminal from the kotlin-wasm-wasi-template root directory:

  • To run the application in Node.js:

    ./gradlew wasmWasiNodeRun
  • To run the application in Deno:

    ./gradlew wasmWasiDenoRun
  • To run the application in WasmEdge:

    ./gradlew wasmWasiWasmEdgeRun

    The terminal displays a message when your application is built successfully:

    Kotlin/Wasm and WASI app

Test the application

You can also test that the Kotlin/Wasm application works correctly across various virtual machines.

In the Gradle tool window, run one of the following Gradle tasks from kotlin-wasm-wasi-example | Tasks | verification:

  • wasmWasiNodeTest to test the application in Node.js.

  • wasmWasiDenoTest to test the application in Deno.

  • wasmWasiWasmEdgeTest to test the application in WasmEdge.

Kotlin/Wasm and WASI test tasks

Alternatively, run one of the following commands in the terminal from the kotlin-wasm-wasi-template root directory:

  • To test the application in Node.js:

    ./gradlew wasmWasiNodeTest
  • To test the application in Deno:

    ./gradlew wasmWasiDenoTest
  • To test the application in WasmEdge:

    ./gradlew wasmWasiWasmEdgeTest

You can see the test results:

Kotlin/Wasm and WASI test

What's next?

Join the Kotlin/Wasm community in Kotlin Slack:

Join the Kotlin/Wasm community

Try more Kotlin/Wasm examples:

Last modified: 08 November 2024