You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
svelte/packages/svelte/tests
Paolo Ricciuti 113a3daab2
fix: don't define `error.message` if it's not configurable (#16149)
3 months ago
..
compiler-errors feat: State declarations in class constructors (#15820) 4 months ago
css fix: correctly parse escaped unicode characters in css selector (#15976) 4 months ago
hydration feat: functional template generation (#15538) 4 months ago
migrate fix: improve error message for migration errors when slot would be renamed (#15841) 4 months ago
motion feat: allow non-numeric values to be tweened by snapping immediately to new value (#14941) 8 months ago
parser-legacy chore: update acorn parser `ecmaVersion` to parse import attributes (#16098) 3 months ago
parser-modern feat: allow generics on snippets (#15915) 4 months ago
preprocess chore: switch to `tinyglobby` (#15388) 6 months ago
runtime-browser fix: properly hydrate dynamic css props components and remove element removal (#16118) 3 months ago
runtime-legacy fix: better `$inspect.trace()` output (#16131) 3 months ago
runtime-runes fix: don't define `error.message` if it's not configurable (#16149) 3 months ago
server-side-rendering fix: destructuring state in ssr (#16102) 3 months ago
signals chore: squelch test console output (#15807) 5 months ago
snapshot fix: correctly transform reassignments to class fields in SSR mode (#16051) 3 months ago
sourcemaps feat: add partial evaluation (#15494) 5 months ago
store chore: simplify flushing (#15348) 7 months ago
types fix: Add `bind:focused` to `HTMLAttributes` (#15122) 7 months ago
validator fix: warn when using rest or identifier in custom elements without props option (#16003) 3 months ago
.gitignore breaking: init Svelte 5 2 years ago
README.md docs: note more breaking changes 2 years ago
animation-helpers.js fix: use WAAPI to control timing of JS-based animations (#13018) 1 year ago
helpers.js feat: add source name logging to `$inspect.trace` (#16060) 3 months ago
html_equal.js chore: better HTML normalization test helper (#16056) 3 months ago
suite.ts chore: ignore test directories left over from other branches (#10525) 2 years ago

README.md

Test repo

This repo tries to migrate as many tests from the currente Svelte project over to test against the new compiler/runtime.

Differences to the old test suite

  • compiler options are different currently, a wrapper function in helpers.js was added and call sites rerouted to that
  • regex in the loader was adjusted, a $ was added to the import * as .. regex (because the new runtime does import * as $ from .. for the runtime)
  • vitest.config.js was altered: resolve-svelte plugin also aliases svelte (the current runtime import) and test.dir was adjusted because the monorepo structure is different (compiler/runtime are separate packages here currently)
  • new runtime does not expose things like raf etc, which were used in some tests (runtime for example; for transition/animation tests). These are commented out for now
  • when changing an attribute, the JSDOM does not reflect the value immediately anymore because the runtime does update the DOM in after a tick, not synchronously - this results in many tests needing additional await Promise.resolve() lines

Breaking changes

  • Order of list insertions has changed: It's now back to front because that's faster
  • Slight timing differences mean that things may fire less in some cases (behavior should be unaffected though) - see component-binding-each-remount-unkeyed for an example
  • It's currently possible to create infinite loops with $: invoking each other
  • Fallback value is now set on all undefined values, not just on the first one
  • CSS is no longer minified. Unused styles are instead commented out
  • :global(...) compound selectors (e.g. .foo:global(.bar) or :global(.foo).bar) are no longer permitted. These are nonsensical and don't do anything useful in Svelte 4 — better to just get rid of them
  • transitions: when one element fades out and a new one (which is on the same element but another instance of it) fades in at the same time, the new one is now below the old one (was above before)
  • transitions: now wait one tick before they start playing to align with web animations API

TODOs

  • the new runtime does not expose named exports such as svelte/store yet, so can't test those
  • event this context is not preserved due to event delegation etc. Problem? Or necessary/ok breaking change?
  • order of operations should be preserved: first all attribute setters (spread props, static props) in order, then mutation directives (actions, bindings) in order, then style/class directives in order

Tests that succeeded but need a closer look

  • $$slot was modified to succeed, see TODOs inside for more info
  • await-component-oncreate needs to await Promise.resolve() because onMount runs async, too. Is this ok?
  • component-slot-fallback-2 has one check commented out, because store subscriptions are deduplicated at the runtime level now. Should this be seen as a breaking change? If yes, ok?

Tests that are not copied over yet

  • everything except runtime is missing so far
  • animation tests within runtime folder were not copied over
  • beforeUpdate/afterUpdate tests