This module performs the translation of Kotlin source code to JavaScript.
There are various Kotlin APIs to JavaScript environments in the standard library.
The Kotlin Standard Library for JS is built with gradle, see the corresponding module's ReadMe.
Any Kotlin test cases using the org.junit.Test annotation and the kotlin.test package, such as this test case are automatically converted to JavaScript using QUnit.
This allows the test cases to be run directly in a web page in any web browser.
There is a simple sample which shows how to use the Kotlin Standard Library from inside JavaScript in a web page.
We love contributions! The JavaScript translation could really use your help! If you fancy contributing:
- check the contributing section on general stuff like getting the code etc
- try fix one of the pending JavaScript translation issues
The following Gradle tasks are responsible for testing the Kotlin/JS compiler:
:js:js.tests:jsIrTest
— run JS tests with the K1 frontend and with ES5 as the target.:js:js.tests:jsIrES6Test
— run JS tests with the K1 frontend and ES6 as the target.:js:js.tests:jsFirTest
— run JS tests with the K2 frontend and ES5 as the target.:js:js.tests:jsFirES6Test
— run JS tests with the K2 frontend and ES6 as the target.:js:js.tests:test
— run all JS tests
The JavaScript files generated from the test files are located in the following directories, divided by the translation mode:
js/js.tests/build/out
— JS files generated with theFULL
translation mode (all modules are compiled into one big JS file)js/js.tests/build/out-min
— the same as previous, but with DCE applied.js/js.tests/build/out-per-module
— JS files generated with thePER_MODULE
translation mode (each module is compiled into a separate JS file)js/js.tests/build/out-per-module-min
— the same as previous, but with DCE applied.
There are multiple kinds of tests. Here are some of them:
- Box tests. Those are the tests that we are often most interested in, they are located in
js/js.translator/testData/box
. Such tests must contain afn box(): String
function. If this function returns"OK"
, the test is considered passed, and if it returns anything else, the test is considered failed. - Line number tests, located in
js/js.translator/testData/lineNumbers
. These are to ensure that the debug info in the generated JavaScript matches some expectation. The expectation is written in a comment staring with// LINES(JS_IR):
or// LINES(ClassicFrontend JS):
or// LINES(FIR JS_IR):
. These comments contain a list of line numbers in the test file that the compiler output is generated from. The actual line numbers can be viewed in the generated JS file whose name ends with-lines.js
. - TypeScript export tests, located in
js/js.translator/testData/typescript-export
. These test that the generated.d.ts
(TypeScript definitions) file matches the reference.d.ts
file. - Also, some tests located in
compiler/testData/codegen
are shared between the JS and the JVM backends.
There is a helpful tool for running and debugging JS code generated from test files right in IntelliJ IDEA.
Note that this will only work for files generated with the IR backend in the FULL
translation mode,
because these files are self-sufficient and don't require any dependencies.
Just open a generated JS file located in js/js.tests/build/out
, select
the "run IR test in node.js" run configuration in IDEA, and click on the "Run" or "Debug" icon.
The test output will be printed in the console.
Bonus: debugging is supported! You can set a breakpoint in a test file, open the generated JS file, select the "run IR test in node.js" run configuration and click on the "Debug" icon. The execution should pause and the breakpoint will be hit. This works because a source map located next to the generated JS file.