We are an open source project on GitHub and would enjoy your contributions! Please open a new issue before working on a PR that requires significant effort. This will allow us to make sure the work is in line with the project's goals.
The extension makes use of the VSCode Language Server client package to integrate with terraform-ls for language features. The directions below cover how to build and package the extension; please see the terraform-ls
documentation for how to build the language server executable.
- VSCode >= 1.61
- Node >= 16.13.2
- npm >= 8.x
git clone https://github.com/hashicorp/vscode-terraform
After cloning the repo, run npm install
to install dependencies. There's an included build task to compile the TypeScript files to JavaScript; you can run it directly with npm run compile
.
> npm install
> npm run compile
In order to use an independently built or installed version of terraform-ls, you will need to set
terraform.languageServer.path
to the correct executable path.
The extension can be run in a development mode via the launch task called Run Extension
. This will open a new VS Code window with the extension loaded, and from there you can open any files or folders you want to check against. This extension development window can also be used to run commands or any other feature the extension provides.
New to VS Code development? You can get started here
The extension can be run in a development mode via the launch task called Run Web Extension
. This will open a new VS Code window with the extension loaded in 'desktop' context, which is close to what a Github Codespace operates as.
The extension can be run in a browser like github.dev or vscode.dev, except locally by running:
npm run web
The extension can be run in vscode.dev directly by sideloading the extension. This is the closet to running the extension in production as you can get. To sideload the extension:
npm run web:serve
npm run web:tunnel
Then follow https://code.visualstudio.com/api/extension-guides/web-extensions#test-your-web-extension-in-on-vscode.dev
Automated unit
and integration
tests can be written using mocha and live inside ./src/test
with file pattern *.test.ts
.
It is required that
terraform
is available on$PATH
to run the tests.
To run the unit tests
from the command-line run:
> `npm test:unit`
To run the integration tests
from the command-line without any configuration, run npm test
. By default, npm test
will test against VS Code Stable. If you want to test against a different VS Code version, or if you want to have VS Code remain open, use an environment variable to indicate which version of VS Code to test against:
# VS Code Stable is open, use Insiders:
> VSCODE_VERSION='insiders' npm test
# VS Code Insiders is open, use Stable:
> VSCODE_VERSION='stable' npm test
# Test against VS Code v1.55.8:
> VSCODE_VERSION='1.55.8' npm test
To run the integration
tests in PowerShell, set the environment variable accordingly:
# VS Code Stable is open, use Insiders:
> $env:VSCODE_VERSION ='insiders'
> npm test
The tests can also be run within VSCode itself, using the launch task Run Extension Tests
. This will open a new VS Code window, run the test suite, and exit with the test results.
End to end acceptance tests with the extension running against the language server are a work in progress. An example can be seen in ./src/test/integration/symbols.test.ts
.
Unfortunately automated user input does not appear to be possible (keypresses, cursor clicks) at the moment, but some integration testing can be performed by using the vscode API to open/edit files, and triggering events/commands such as language server requests and verifying the responses.
The terraform init
command runs automatically when tests are executed.
To run unit tests for the web:
npm run test:unit:web
Sample files for tests should be added to the ./testFixture
folder, this is the folder vscode will open during tests. Starting from this folder will prevent the language server from walking other folders that typically exist such as node_modules
.
To package the extension into a platform specific extension
VSIX ready for testing run the following command:
npm run package -- --target=win32-x64
Replace target
with the platform/architecture combination that is on the supported matrix list.
platform | terraform-ls | extension | vs code |
---|---|---|---|
macOS | darwin_amd64 | darwin_x64 | ✅ |
macOS | darwin_arm64 | darwin_arm64 | ✅ |
Linux | linux_amd64 | linux_x64 | ✅ |
Linux | linux_arm | linux_armhf | ✅ |
Linux | linux_arm64 | linux_arm64 | ✅ |
Windows | windows_amd64 | win32_x64 | ✅ |
Windows | windows_arm64 | win32_arm64 | ✅ |
This will run several chained commands which will download the specified version of terraform-ls, minify the extension using Webpack, and package the extension using vsce into a VSIX.
You can run
npm run package
without paramaters, but this will not produce a platform specific extension.