Commit graph

368 commits

Author SHA1 Message Date
Will Binns-Smith
dd217c71b9 Benchmark Parcel (vercel/turbo#322)
* Benchmark Parcel

* add Parcel to the CI benchmarks

* move some turbopack dependencies to the bundler as they conflict with other bundlers

Co-authored-by: Tobias Koppers <tobias.koppers@googlemail.com>
2022-09-08 13:08:25 +02:00
Will Binns-Smith
abcdd78623 Benchmark Next.js 11 and 12 (vercel/turbo#304)
This implements benchmark support for Next.js 12. Next.js (the tool) expects to be able to resolve from the `next` package in the cwd, so it must be installed alongside the other node_modules in the test.  `prepare` was added to the Bundler trait to handle this case.

Test Plan: `TURBOPACK_BENCH_ALL=all cargo bench -p next-dev`


Co-authored-by: Alex Kirszenberg <1621758+alexkirsz@users.noreply.github.com>
Co-authored-by: Tobias Koppers <1365881+sokra@users.noreply.github.com>
2022-09-08 05:00:32 +00:00
Tobias Koppers
512539821d fix runtime code for server rendered content source (vercel/turbo#315)
move transition into turbopack
2022-09-07 15:56:10 +02:00
Will Binns-Smith
12e5f19a84 Benchmark against Vite (vercel/turbo#299)
This adds a comparison against Vite to our benchmark suite, running the startup, change, and restart benchmarks.

Test Plan: `cargo bench`


Co-authored-by: Tobias Koppers <1365881+sokra@users.noreply.github.com>
2022-09-07 00:09:06 +00:00
Tobias Koppers
b78ede6099 fix benchmark compare actions (vercel/turbo#318)
The benchmark github action didn't correctly copy and use the executables used in benchmarks via CARGO_BIN_EXE_*.

This adds a CARGO_BIN_EXE_* runtime override to the github action to allow to use correct executable.

It will show correct results for next-dev benchmarks too, e. g. here an example of reverting vercel/turbo#295 
![image](https://user-images.githubusercontent.com/1365881/188696769-d393cd45-b08f-4fd5-ad69-2d38a54bcd92.png)
2022-09-06 17:34:51 +00:00
Tobias Koppers
7df0c410fc improve HMR update performance (vercel/turbo#295)
* avoid cloning Strings and reading/calling many functions when building ecmascript chunk content
* introduce `ReadRef` to allow storing snapshot of a value in values
* use snapshot trees to allow caching more function calls and reads

Before:
```
updated in 35ms (18 tasks)
updated in 34ms (18 tasks)
updated in 37ms (18 tasks)
updated in 31ms (18 tasks)
updated in 40ms (19 tasks)
updated in 37ms (18 tasks)
updated in 37ms (18 tasks)
updated in 34ms (18 tasks)
updated in 35ms (18 tasks)
updated in 52ms (18 tasks)
```

After:
```
updated in 6.105ms (19 tasks)
updated in 5.279ms (18 tasks)
updated in 10.471ms (19 tasks)
updated in 6.863ms (18 tasks)
updated in 4.593ms (18 tasks)
updated in 4.173ms (18 tasks)
updated in 5.352ms (18 tasks)
updated in 10.69ms (18 tasks)
updated in 5.065ms (18 tasks)
updated in 6.309ms (19 tasks)
```

a 5x performance improvement
2022-09-06 14:02:07 +00:00
Will Binns-Smith
aab23b38da Parameterize devserver used in benchmarks (vercel/turbo#298)
This implements the basics of parameterizing the tool/devserver used in these tests. Following PRs will implement benchmarking of Vite, bun, Parcel, etc.

Test Plan: `cargo bench -p next-dev` and verify no change in performance.
2022-09-06 09:39:11 +00:00
Will Binns-Smith
7d79ce5029 Benchmark restart time for dev server (vercel/turbo#244)
This implements a benchmark of restarting the devserver after successfully starting it and shutting it down.

## Question/TODO: 

Since our goal is metrics that don't scale with project size, should we
assert that the small/medium benchmark results don't differ?

Test Plan: `cargo bench -p next-dev`
2022-09-06 08:30:08 +00:00
Will Binns-Smith
80d0a86655 Basic change bench for dev server (vercel/turbo#297)
This builds on vercel/turbo#240, starting up a server and then benchmarking the response to a small file change.

This change does not introduce nor remove any dependencies. A followup
benchmark should do so.

Test Plan: cargo bench -p next-dev


Co-authored-by: Tobias Koppers <1365881+sokra@users.noreply.github.com>
2022-09-06 07:34:25 +00:00
Tobias Koppers
d78084a0b4 Test benchmark cases in separate job (vercel/turbo#311)
Move benchmark test into separate job and run them for windows and macOS too
2022-09-06 06:48:01 +00:00
Alex Kirszenberg
e55a098efd CSS HMR (vercel/turbo#296)
Implements HMR for CSS chunks and paves the way for accepting HMR updates for the HTML entry point as well.
2022-09-03 11:38:14 +00:00
Tobias Koppers
42dda2f181 improve vizualization (vercel/turbo#225) 2022-08-30 16:31:35 +00:00
Alex Kirszenberg
1e8d63d10d Postfix join and try_join (vercel/turbo#300)
Instead of dropping back to prefix calling form in `try_join_all(iterator_of_intofutures).await?`, we now use postfix form `iterator_of_intofutures.try_join().await?`.
2022-08-30 15:15:06 +00:00
Will Binns-Smith
43f25065c8 Benchmarks: assert that no runtime errors occur when loading pages (vercel/turbo#285)
This adds an assertion that no runtime (browser) errors occurred when
loading a benchmark page.

Test Plan: Temporarily removed the npm install for the test app and
verified the benchmark failed as the test app requires react, react-dom.
Restored the npm install and verified the benchmark runs to completion.
2022-08-29 16:18:26 -07:00
Will Binns-Smith
2ee6039ad0 Benchmarks: Install node_modules and reuse test directories (vercel/turbo#284)
This:

* Runs `npm install` in test directories to provide turbopack with modules necessary to bundle them.
* Reuses test directories for iterations across the given benchmark. This prevents unnecessary file writing and `npm install` for each iteration, improving the times to run benchmarks.

Currently cherry-picks vercel/turbo#278 as it's necessary along with vercel/turbo#277.

Test Plan: Connected to the running devserver mid-test and confirmed no errors are thrown and the triangle is rendered correctly.
2022-08-29 15:41:26 -07:00
Alex Kirszenberg
8f54f35e90 HMR support + React Refresh (vercel/turbo#252)
This PR implements HMR support with React Refresh built-in.

For now, in order for React Refresh to be enabled, you'll need the `@next/react-refresh-utils` package to be resolveable: `yarn add @next/react-refresh-utils` in your app folder.

* Depends on vercel/turbo#266 
* Integrated both HMR-and-React-Refresh-specific logic directly into the ES chunks' runtime. Webpack has more complex setup here, but for now this makes the logic much more easy to follow since everything is in one place. I have yet to implement the "dependencies" signature for `hot.accept`/`hot.dispose`, since React Refresh does not depend on them. We'll have to see if they're even used in the wild or if we should deprecate them.
* Only implemented the [module API](https://webpack.js.org/api/hot-module-replacement/#module-api), not the [management API](https://webpack.js.org/api/hot-module-replacement/#management-api). We apply all updates as soon as we receive them.
* Added support for "runtime entries" to ES chunks. These are assets that will be executed *before* the main entry of an ES chunk. They'll be useful for polyfills in the future, but for now they're here to evaluate the react refresh runtime before any module is instantiated.

Next steps for HMR:
* Implement CSS HMR
* Implement (or decide to deprecate) the [dependencies form](https://webpack.js.org/api/hot-module-replacement/#accept) of `hot.accept`/`hot.dispose`
* Clean up `runtime.js` some more: switch to TypeScript, split into multiple files, etc. It'd be nice if all of this could be done at compile time, but how to achieve this is unclear at the moment. _Can we run turbopack to compile turbopack?_
2022-08-26 16:30:04 +00:00
Tobias Koppers
32d10a037a resolve entrypoint to allow it to select jsx automatically (vercel/turbo#278) 2022-08-26 11:26:58 +00:00
Tobias Koppers
3148d3b67b fix windows path separators (vercel/turbo#281) 2022-08-25 15:44:11 +00:00
Tobias Koppers
5156dcfc25 add root_dir to support monorepos (vercel/turbo#260)
This adds an option to pass the root dir from CLI, before it was always the current directory
2022-08-24 18:41:16 +00:00
Will Binns-Smith
e783ec8302 Benchmark startup time for bundling many modules (vercel/turbo#240)
* Basic startup bench for dev server

* fixes to benchmarking (vercel/turbo#268)

* use bench profile for benchmarking

* make setup and teardown not part of the measurement

add support for async setup and teardown

share browser between measurements

* updates for changes TestApp

Co-authored-by: Tobias Koppers <tobias.koppers@googlemail.com>
2022-08-24 11:36:08 -07:00
Justin Ridgewell
77e46e2670 Normalize Windows paths into Unix paths (vercel/turbo#251)
The snapshot tests were failing because Windows paths were sneaking into the `FileSystemPathVc::path`. Reviewing, the `::new` method didn't normalize `\` into `/`, and the various `::join` methods didn't either. This came up in both the chunk ids, and the request pathnames used by the server.

No path with backslash should enter the FileSystemPath APIs, they should be normalized during conversion from `Path` to `String`

Co-authored-by: Tobias Koppers <1365881+sokra@users.noreply.github.com>
2022-08-23 16:10:38 +00:00
Tobias Koppers
44eec9b9e0 only create pages for .js etc. files in pages (vercel/turbo#255) 2022-08-23 13:24:25 +00:00
Tobias Koppers
078f4d8191 Do not execute .css during server rendering (vercel/turbo#254)
Ignore any non-code chunks for server rendering
2022-08-23 11:47:39 +00:00
Tobias Koppers
4935008b88 single thread for test cases (vercel/turbo#264) 2022-08-22 16:02:09 +00:00
LongYinan
e16bd1b584 Group and prettier log messages (vercel/turbo#245)
### Default flags

`cargo run --bin node-file-trace -- build --context-directory crates/turbopack/tests/node-file-trace  ./crates/turbopack/tests/node-file-trace/integration/loopback.js`

<img width="1201" alt="image" src="https://user-images.githubusercontent.com/3468483/184812301-3aa644c8-edcc-43f5-9b07-1a0c11102d4b.png">

### `--show-all`

`cargo run --bin node-file-trace -- build --show-all --context-directory crates/turbopack/tests/node-file-trace  ./crates/turbopack/tests/node-file-trace/integration/loopback.js`

<img width="1435" alt="image" src="https://user-images.githubusercontent.com/3468483/184812439-14543700-f3c9-4b11-924b-68d6b42bd545.png">

### `--log-detail`

`cargo run --bin node-file-trace -- build --log-detail --context-directory crates/turbopack/tests/node-file-trace  ./crates/turbopack/tests/node-file-trace/integration/loopback.js`

<img width="1257" alt="image" src="https://user-images.githubusercontent.com/3468483/184812582-ab62ae77-2726-4387-872c-df38c4337d40.png">




Co-authored-by: Tobias Koppers <1365881+sokra@users.noreply.github.com>
2022-08-22 09:35:09 +00:00
Leah
c867a32ba1 fix: fs errors when running next-dev with pages (vercel/turbo#253) 2022-08-18 14:12:40 +00:00
Tobias Koppers
c7ff4150c8 fix consistency issues (vercel/turbo#224)
There are a bunch or problems with invalidations:

* The fs impl watches path case-insenstive. This means two paths might conflict when on a case-sensitive filesystem. It uses an array of Invalidators now
* Move the next-dev bootstrapping logic out of the run_once scope (which is not updated when invalidations occur). Instead it's executed inside the request handling resp. update stream where changes can be handled.
* `TransientValue` was not an Value type actually. This fixes that.
* Adds a new `TransientInstance` wrapper to pass transient by reference.
* `strongly_consistent` was broken when using nested TaskScopes. This fixes that.
2022-08-16 13:12:09 +00:00
Tobias Koppers
eab61f3c65 add basic next pages support (vercel/turbo#223)
Server Rendering:

* This adds an additional ContentSource to next-dev which takes care of handling the `pages` directory.
* The content source creates a ServerRenderedAsset from each file in the `src/pages` or `pages` directory and a AssetGraphContentSource for that.
* The ServerRenderedAsset will reference an underlying asset for the node.js context which will be passed to the node executable for rendering. It uses a WrapperAsset to add additional communication logic.

Client Transition:

* When annotating `import`s with `transition: "next-client"` the NextClientTransition is used
* This transition changes the environment to browser
* It wraps the referenced asset with a next-hyrdation wrapper asset
* It leaves a little module in the previous context which exports a list of URLs for chunks needed.
* The NextClientTransition takes a client_chunking_context as argument which specifies how the client code is chunked.
2022-08-15 17:26:37 +00:00
Will Binns-Smith
935e46f995 next-dev test runner: ask os for free port (vercel/turbo#238)
These integration tests have been flaky, failing when a "free" port turns out to be in use. Since nextest parallelizes test runs and portpicker guesses and checks free ports [0], I'm guessing that there's a collision occurring. 

Instead, ask the operating system for a free port by binding to port 0 and read the port back from the resulting address.

Test Plan: Tried local runs with nextest, but those succeeded before as well. I'll probably retry things on CI a few times.

[0] 912f913ac3/src/lib.rs (L53)
2022-08-12 21:21:21 +00:00
Will Binns-Smith
c2fb81dd37 next-dev test runner: Ensure skipped tests fail (vercel/turbo#216)
This adds test runs for integration tests in `__skipped__` directories,
ensuring that they fail, otherwise they should probably be unskipped.

Test Plan: Temporarily moved a succeeding test into a `__skipped__`
directory and ensured that cargo test began failing that test.
2022-08-11 09:39:32 -07:00
Will Binns-Smith
4778270305 next-dev test runner: Check in and use webpack's chunk test cases (vercel/turbo#212)
This commits webpack's chunk tests (test/cases/chunks) and skips those
that do not pass yet.

Test Plan: `cargo test -p next-dev -- --nocapture` and verify the
non-skipped tests run.
2022-08-11 09:33:25 -07:00
Alex Kirszenberg
1d8b74c655 Introduce FileContent, Versioned, and refactor dev server updates (vercel/turbo#209)
This prepares the way for HMR (vercel/turbo#160) by letting us diff assets between
versions.

1. Add `Asset::versioned_content` which returns a `VersionedContentVc`.
2. `VersionedContent`s have a built-in versioning mechanism as they must implement `version() -> VersionVc`. `Version` is a trait, so `VersionVc` can contain a specific version implementation by asset type. This is particularly important because... 
3. A `VersionedContentVc` can be diffed with a `VersionVc` from the same underlying `VersionedContent` type with `content.update(from: version)`. This returns an `UpdateVc` which describes the steps necessary to update from one verson to the next. In the case of ES chunks, this will be a map of added, and modified module IDs, with their respective factories, and a set of deleted module IDs.
4. Implement diffing for ES chunks.
2022-08-11 08:03:38 +00:00
Will Binns-Smith
51c69f20f8 next-dev test runner: Implement manual debug mode (vercel/turbo#211)
This implements a manual debug mode for next-dev tests, enabled by
setting the environment variable TURBOPACK_DEBUG_BROWSER to any value.

It launches the test browser in non-headless mode and holds it open
~~indefinitely~~ until the user closes it, so it can be inspected.

Test Plan: `TURBOPACK_DEBUG_BROWSER=1 cargo test -p next-dev --
test_crates_next_dev_tests_integration_chunks_circular_correctness
--nocapture` and verify the browser is opened non-headless and is held
open
2022-08-10 10:14:01 +00:00
Alex Kirszenberg
1a5d175d8d Update toolchain to 2022-08-02 (vercel/turbo#215)
* Update toolchain to 2022-08-02

* Fix warnings
2022-08-09 19:38:05 +02:00
Will Binns-Smith
7bd5321b09 next-dev test runner (vercel/turbo#172)
This is a very early version of the next-dev test runner. I'm opening this early to get thoughts from folks re: the direction of the design and implementation.

Fixes vercel/turbo#204 

Currently it:
* Discovers integration test fixtures from the filesystem. Right now these are expected to be single files that get bundled and will eventually include assertions. This is powered by the test-generator crate, which allows us not to have to manually enumerate each case. We could consider using this for the node-file-trace tests as well.
* Starts the dev server on a free port and opens a headless browser to its root. The browser control is implemented with the https://crates.io/crates/chromiumoxide crate, which expects Chrome or Chromium to already be available.

Eventually it will:
* [x] Implement a minimal test environment loaded in the browser so that assertions can be run there from bundled code.
* [x] Report back the results of these assertions to rust, where we can pass/fail cargo tests with those results.

In the future it could:
* Possibly include snapshot-style tests to assert on transformed results. This could be in the form of fixture directories instead of files cc @jridgewell
* Support expressing special configuration of turbopack in a fixture, possibly as another file in the fixture directory.
* [x] ~Possibly support distributing tests to a pool of open browsers instead of opening and closing for each test.~

Test Plan: See next PRs
2022-08-09 16:20:30 +00:00
Tobias Koppers
659a5fd83d add issue reporting to next dev (vercel/turbo#208) 2022-08-08 07:39:52 +00:00
Leah
1277c36e35 refactor turbo-tasks-macros (vercel/turbo#198)
Changes attribute/argument parsing to the more usual `field = "value"` / `turbo_tasks(trace_ignore)`
2022-08-05 06:26:22 +00:00
Leah
5e4ba91c7c rename ModuleAsset (vercel/turbo#206) 2022-08-05 06:20:42 +00:00
Leah
71429b9beb simplify turbo_tasks::value (vercel/turbo#196)
Removes the trait arguments and registers them separately
2022-08-04 21:58:32 +00:00
Leah
64bb520332 add open-browser option (vercel/turbo#199)
Fixes https://github.com/vercel/turbo-tooling/issues/171
2022-08-04 21:58:19 +00:00
Tobias Koppers
796f605301 track processing path for issues (vercel/turbo#205)
allow to attach context at any point

show processing path in output

move cli issue display into separate crate
2022-08-04 21:14:09 +00:00
Leah
1d4821382b fix css layer import (vercel/turbo#195)
kdy1 fixes this upstream
2022-08-03 03:37:56 +00:00
Will Binns-Smith
01a7e41834 Extract server creation into own function and module (vercel/turbo#191)
* Extract server creation into fn

* Use builder pattern and anyhow context
2022-08-02 16:28:11 -07:00
Alex Kirszenberg
8fad8a6881 Custom debug implementation for Vcs (vercel/turbo#193)
This PR builds our own `Debug`-like derive-macro machinery for formatting structs, relying on `std::fmt::Formatter` for the actual formatting.

### Usage

A new `ValueDebug` trait is automatically implemented for all `#[turbo_tasks::value]`s, which has a single `.dbg()` method which resolves to a debug representation that can then be printed to the screen. `#[turbo_tasks::value_trait]` also implement the `.dbg()` method directly.

```rust
dbg!(any_vc.dbg().await?);
```

If you have a `#[turbo_tasks::value]` struct with a field that doesn't implement `Debug`, you'll want to declare that field as `#[debug_ignore]`. For instance:

```rust
#[turbo_tasks::value(ContentSource, serialization: none, eq: manual, cell: new, into: new)]
pub struct TurboTasksSource {
    #[debug_ignore]
    #[trace_ignore]
    pub turbo_tasks: Arc<TurboTasks<MemoryBackend>>,
}
```

### Why not use `Debug` directly?

We can't use `Debug` because our values are resolved asynchronously and can nest `Vc`s arbitrarily. I tried using `futures::executor::block_on` to resolve them synchronously in a `Debug` implementation but that causes deadlocks.
2022-08-02 17:36:48 +00:00
Tobias Koppers
12d720ff48 refactor lazy asset to lazy graph content source (vercel/turbo#186) 2022-08-01 07:53:09 +00:00
Tobias Koppers
41c2dfd2de introduce ContentSource as source for the dev server (vercel/turbo#185)
and potentially a next build in future
2022-08-01 07:02:53 +00:00
Tobias Koppers
52557b1c4d introduce an Environment and track that for the graph and Assets (vercel/turbo#167) 2022-07-27 22:33:14 +00:00
Will Binns-Smith
45b409393d Move browser opening to next-dev cli (vercel/turbo#169)
Cherry-picking this from my work on the next-dev test runner.

This moves browser opening from the turbopack-dev-server crate into the next-dev crate, which has the cli entrypoint that runs the dev server. It looks like the dev server package is meant to be used as a library (it's only a library crate), and having this external side effect feels unexpected and makes it difficult to use this crate in situations like a test runner for next-dev, where we should test with a headless web browser.

Alternatively, opening the browser could be an option passed when creating the dev server, but this feels a bit cleaner to me.

Test Plan: `cargo run -p next-dev` and verify the browser still opens and successfully connects to the dev server.
2022-07-27 19:09:11 +00:00
Tobias Koppers
eb417b1e25 cleanup compile target (vercel/turbo#157) 2022-07-27 11:36:10 +02:00
Tobias Koppers
d4a50bfd0c reduce number of clippy warnings (vercel/turbo#164) 2022-07-27 08:13:29 +00:00
LongYinan
a55a831b39 Node Module Trace webpack plugin (vercel/turbo#140)
* Initialize Node.js/TypeScript workspace

* node-module-trace Webpack plugin

* Add new fmt checks to pipeline

* Popup unwind error

* Implement --exact flag

* Yarn 3.2.2

* Reformat toml files

* Fix socket io test, 100ms timeout is too long

* remove unnecessary CI cache config

* regenerate lockfile from old lockfile, align the dependencies version

* Run nmt tests in system tmp dir

* Apply code review suggestions

* allow to wait for task completion and propagate errors and panics

* revert method addition

* spawn_root_task should be sync

Co-authored-by: Tobias Koppers <tobias.koppers@googlemail.com>
2022-07-22 12:36:08 +02:00
Tobias Koppers
144e95bc4e allow to switch to eager compiling 2022-07-21 13:22:42 +02:00
Tobias Koppers
fb1bc5a55f make websocket task special as it never completes
aggregate timings before displaying
2022-07-20 19:49:27 +02:00
Tobias Koppers
a12541a06a add performance table 2022-07-19 10:54:53 +02:00
Justin Ridgewell
099e5c7c4b next-dev: Fix watching relative directories
Fixes vercel/turbo#107
2022-07-18 17:56:26 -04:00
Tobias Koppers
aa64055055 add util for formating durations 2022-07-18 21:39:55 +02:00
Tobias Koppers
f134e1104c fixup paths 2022-07-18 18:11:13 +02:00
Tobias Koppers
85ae4b5036 add bootstrap logic for chunks 2022-07-13 08:37:12 +02:00
Leah
2909fd07ca fmt 2022-07-12 17:17:23 +02:00
Leah
cd647d7fc4 match next dev args 2022-07-12 17:09:16 +02:00
Tobias Koppers
99e015c41f complete strongly consistent read
performance improvements
2022-07-08 15:05:51 +02:00
Tobias Koppers
878dd09578 improve visualization
make TransientValue functional
make console-subscriber an optional feature
avoid cloning when calling a function
capture timings of task executions
fix LazyAsset
expose graph from dev server
2022-07-08 14:52:28 +02:00
Tobias Koppers
89f6ad1151 cleanup and documentation 2022-06-30 13:54:04 +02:00
Leah
667507c5ca don't like these quoted names lol 2022-06-29 18:09:41 +02:00
Tobias Koppers
db41ef8432 place the persistent cache behind a feature flag 2022-06-29 09:40:11 +02:00
Tobias Koppers
54985ab83d chunking and bugfixes 2022-06-28 10:21:04 +02:00
Tobias Koppers
b3df7a862e abstract lazy graph into Asset decorator
enable watching for dev server
2022-06-14 12:53:46 +02:00
Tobias Koppers
e7c2d1e932 add initial dev-server and next-dev cli 2022-06-14 12:53:46 +02:00