A modern runtime for JavaScript and TypeScript.
Find a file
Yoshiya Hinosawa 83f15ece09
feat(test): create coverage reports when --coverage specified in deno test (#28260)
This PR updates the behavior of `deno test --coverage` option. Now if
`--coverage` option is specified, `deno test` command automatically
shows summary report in the terminal, and generates the lcov report in
`$coverage_dir/lcov.info` and html report in `$coverage_dir/html/`

This change also adds `--coverage-raw-data-only` flag, which prevents
the above reports generated, instead only generates the raw json
coverage data (which is the same as current behavior)
2025-04-18 18:56:14 +09:00
.cargo feat: bring back WebGPU (#20812) 2023-12-09 01:19:16 +01:00
.devcontainer chore(devcontainer): add clang to cargo build (#28345) 2025-03-02 03:47:38 +00:00
.github docs: contributing guidelines (#28945) 2025-04-17 12:17:24 -04:00
bench_util chore: forward v2.2.10 release commit to main (#28897) 2025-04-14 16:10:16 -07:00
cli feat(test): create coverage reports when --coverage specified in deno test (#28260) 2025-04-18 18:56:14 +09:00
ext feat(compile): support for ffi and node native addons (#28934) 2025-04-17 16:01:12 -04:00
resolvers chore: forward v2.2.10 release commit to main (#28897) 2025-04-14 16:10:16 -07:00
runtime feat(compile): support for ffi and node native addons (#28934) 2025-04-17 16:01:12 -04:00
tests feat(test): create coverage reports when --coverage specified in deno test (#28260) 2025-04-18 18:56:14 +09:00
tools chore: box some more large futures (#28806) 2025-04-08 20:54:48 +00:00
.dlint.json chore: enable no-console dlint rule (#25113) 2024-08-20 15:14:37 -04:00
.dprint.json fix(fmt/md): handle callout followed by non-text (#28333) 2025-02-27 22:29:58 +00:00
.editorconfig chore(tests): Remove vestiges of cli/tests folder (#22712) 2024-03-05 13:49:21 -07:00
.gitattributes chore: move cli/tests/ -> tests/ (#22369) 2024-02-10 20:22:13 +00:00
.gitignore feat(coverage): add coverage ignore comments (#26590) 2025-04-15 17:56:55 +00:00
.gitmodules chore: make remaining submodules shallow (#23441) 2024-04-18 19:45:09 +00:00
.rustfmt.toml chore: update copyright year to 2023 (#17247) 2023-01-02 21:00:42 +00:00
Cargo.lock feat(compile): support for ffi and node native addons (#28934) 2025-04-17 16:01:12 -04:00
Cargo.toml feat(compile): support for ffi and node native addons (#28934) 2025-04-17 16:01:12 -04:00
import_map.json chore: update std submodule (#25595) 2024-09-12 22:32:09 +10:00
LICENSE.md chore: Happy New Year 2025 (#27509) 2024-12-31 19:12:39 +00:00
README.md docs: contributing guidelines (#28945) 2025-04-17 12:17:24 -04:00
Releases.md chore: forward v2.2.10 release commit to main (#28897) 2025-04-14 16:10:16 -07:00
rust-toolchain.toml chore: update to rust 1.85 (#28236) 2025-02-25 08:50:01 -08:00

Deno

Twitter badge Bluesky badge Discord badge YouTube badge

the deno mascot dinosaur standing in the rain

Deno (/ˈdiːnoʊ/, pronounced dee-no) is a JavaScript, TypeScript, and WebAssembly runtime with secure defaults and a great developer experience. It's built on V8, Rust, and Tokio.

Learn more about the Deno runtime in the documentation.

Installation

Install the Deno runtime on your system using one of the commands below. Note that there are a number of ways to install Deno - a comprehensive list of installation options can be found here.

Shell (Mac, Linux):

curl -fsSL https://deno.land/install.sh | sh

PowerShell (Windows):

irm https://deno.land/install.ps1 | iex

Homebrew (Mac):

brew install deno

Chocolatey (Windows):

choco install deno

WinGet (Windows):

winget install --id=DenoLand.Deno

Build and install from source

Complete instructions for building Deno from source can be found in the manual here.

Your first Deno program

Deno can be used for many different applications, but is most commonly used to build web servers. Create a file called server.ts and include the following TypeScript code:

Deno.serve((_req: Request) => {
  return new Response("Hello, world!");
});

Run your server with the following command:

deno run --allow-net server.ts

This should start a local web server on http://localhost:8000.

Learn more about writing and running Deno programs in the docs.

Additional resources

  • Deno Docs: official guides and reference docs for the Deno runtime, Deno Deploy, and beyond.
  • Deno Standard Library: officially supported common utilities for Deno programs.
  • JSR: The open-source package registry for modern JavaScript and TypeScript
  • Developer Blog: Product updates, tutorials, and more from the Deno team.

Contributing

We appreciate your help! To contribute, please read our contributing instructions.