Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

#3696 - tc39-test262 Crate #3708

Open
wants to merge 13 commits into
base: main
Choose a base branch
from

Conversation

PawelJastrzebski
Copy link

@PawelJastrzebski PawelJastrzebski commented Feb 29, 2024

This Pull Request closes #3696.

It changes the following:

  • transfers boa_tester parser logic to tools/tc39-test262 crate

@PawelJastrzebski PawelJastrzebski marked this pull request as draft February 29, 2024 13:45
Copy link

codecov bot commented Mar 7, 2024

Codecov Report

Attention: Patch coverage is 0% with 170 lines in your changes are missing coverage. Please review.

Project coverage is 47.37%. Comparing base (6ddc2b4) to head (154f7a1).
Report is 80 commits behind head on main.

❗ Current head 154f7a1 differs from pull request most recent head 5e85673. Consider uploading reports for the commit 5e85673 to get more accurate results

Files Patch % Lines
tools/tc39-test262/src/git.rs 0.00% 58 Missing ⚠️
tools/tc39-test262/src/test_flags.rs 0.00% 55 Missing ⚠️
tools/tc39-test262/src/structs.rs 0.00% 26 Missing ⚠️
tools/tc39-test262/src/test_files.rs 0.00% 20 Missing ⚠️
tools/tc39-test262/src/lib.rs 0.00% 6 Missing ⚠️
tools/tc39-test262/src/read.rs 0.00% 4 Missing ⚠️
tools/tc39-test262/src/edition.rs 0.00% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #3708      +/-   ##
==========================================
+ Coverage   47.24%   47.37%   +0.12%     
==========================================
  Files         476      461      -15     
  Lines       46892    44846    -2046     
==========================================
- Hits        22154    21245     -909     
+ Misses      24738    23601    -1137     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@PawelJastrzebski PawelJastrzebski marked this pull request as ready for review March 16, 2024 10:24
@PawelJastrzebski PawelJastrzebski changed the title #3696 - WIP #3696 - tc39-test262 Crate Mar 16, 2024
Copy link
Author

@PawelJastrzebski PawelJastrzebski left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Merge comments

@@ -220,54 +220,6 @@ impl RunTest<OptimizerOptions, TestResult> for Test {
}
}

/// Creates the test result from the outcome and message.
fn create_result<S: Into<Box<str>>>(
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Moved to helper function (Out of Trait)

@@ -87,9 +93,13 @@ static FEATURE_EDITION: phf::Map<&'static str, SpecEdition> = phf::phf_map! {
// https://github.com/tc39/proposal-set-methods
"set-methods" => SpecEdition::ESNext,

// Regular Expression Pattern Modifiers
// https://github.com/tc39/proposal-regexp-modifiers
"regexp-modifiers" => SpecEdition::ESNext,
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Duplicate in line 76

Copy link
Member

@jedel1043 jedel1043 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for all the work!

It's been several days going back and forth on this PR about whether to put the feature to editions map into the new crate or the tester.

On the one hand, features are part of the test262 suite and we may include them to also get the edition of a test. On the other hand, if we include them, we would need to keep the crate pretty much updated with every new commit to the test262 repo, which would be a pretty big maintenance work for us.

I'm tending towards leaving the editions on the tester, since I don't see many use cases for it aside from engine tests. What do you think?

@PawelJastrzebski
Copy link
Author

I wonder if would be ok for tests that contains unknown features set edition to ESNext as a fallback option. I guess in that case they could be marked as ignored as well.

Thinking long term:

  • test262 repo contains list of features features.txt.
  • We could read from that to find out if missing feature pass through the proposal stage, and only then break the parsing process with an error.

image

@jedel1043
Copy link
Member

I wonder if would be ok for tests that contains unknown features set edition to ESNext as a fallback option. I guess in that case they could be marked as ignored as well.

That would also be a good option for the short-term.

On the long term, I'm trying to push for adding this metadata to test262 (tc39/test262#4161). This would essentially remove the need for the map, probably making it a HashMap<String, u8> in the future.

@@ -39,12 +39,6 @@ static FEATURE_EDITION: phf::Map<&'static str, SpecEdition> = phf::phf_map! {
// https://github.com/tc39/proposal-json-modules
"json-modules" => SpecEdition::ESNext,

// https://github.com/tc39/proposal-source-phase-imports
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Duplicated

@PawelJastrzebski
Copy link
Author

Temporally fallback to ESNext while pending on features map on tc39/test262#4161.

@jedel1043 Could you please take a look on this:
391ac73#diff-91b6a7ace0b3edddaae2e4339b9cc565ce1cb47e735f2ad88805bcb533f3343aL390

I guess with that change we could merge this PR and implement features map parser later.

Copy link
Member

@jedel1043 jedel1043 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

First pass of reviews. It's starting to look really nice!

Comment on lines 26 to 52
pub(crate) trait RunTest<TO, TR> {
/// Runs the test.
fn run(&self, harness: &Harness, verbose: u8, optimizer_options: TO, console: bool) -> TR;

/// Runs the test once, in strict or non-strict mode
fn run_once(
&self,
harness: &Harness,
strict: bool,
verbose: u8,
optimizer_options: OptimizerOptions,
console: bool,
) -> TestResult;
}

pub(crate) trait RunTestSuite<TO, TR> {
/// Runs the test suite.
fn run(
&self,
harness: &Harness,
verbose: u8,
parallel: bool,
max_edition: SpecEdition,
optimizer_options: OptimizerOptions,
console: bool,
) -> SuiteResult;
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we need these to be generic traits? They could also be simple traits without generics, since they're only used internally.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You are right, we can remove generics.

@@ -0,0 +1,24 @@
[package]
name = "tc39-test262"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is test262 available in crates.io? That could potentially be a better name for the crate.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks like test262 it's available.

@@ -292,7 +290,7 @@ static FEATURE_EDITION: phf::Map<&'static str, SpecEdition> = phf::phf_map! {
clap::ValueEnum,
)]
#[repr(u8)]
pub(crate) enum SpecEdition {
pub enum SpecEdition {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To prepare for the test262 changes, this should probably become an open enum instead.

pub struct SpecEdition(u8);

impl SpecEdition {
    const ES5: SpecEdition = SpecEdition(5);
    const ES8: SpecEdition = SpecEdition(8);
}

Comment on lines 20 to 29
pub fn clone_test262(commit: Option<&str>, verbose: u8) -> color_eyre::Result<()> {
const TEST262_REPOSITORY: &str = "https://github.com/tc39/test262";
git::clone(
TEST262_DIRECTORY,
TEST262_REPOSITORY,
&"origin/main",
commit,
verbose,
)
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure if we should expose a clone_repo function. IMO, we should provide a test262 function that takes a struct of options and returns the whole suite, optionally cloning the repo if a path to a valid repo is not provided.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Okey, that seams reasonable to me.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

After longer consideration and refactor I not sure if reading and optionally cloning logic should be in the same function (double responsibility).

  • it would add more complexity to read(...) fn signature as we would have to provide extra information (struct) on each read level (harness, suite, test).
  • if we provide it only on the suite level api in that form can be confusing and inconsistent.

Usage in main:

image

in this example if path to suite would be a direct path to test (.js) test262 would skip clone and return error, causing inconsistent cli behavior.

@jedel1043 please let me know what do you think about it. Maybe I'm missing something and there is a better solution to make it done.

Copy link
Member

@jedel1043 jedel1043 Sep 16, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We don't need the public read to be the same as the read used internally. I'd expect something like having a test262::read that does all the fetch git logic, then a private test262::read_from_dict that is called by test262::read and does the reading tests logic. Also, I'd avoid exposing pub read functions for the other components.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jedel1043 Thanks for clarification.

Please take a look at this changes and let me know if there are closer to the expected result.
027fbb4?diff=split&w=0

Still some work is needed, but I want to make sure that this is the desired direction.


/// Reads the Test262 defined bindings.
pub(super) fn read_harness(test262_path: &Path) -> Result<Harness> {
pub fn read_harness(test262_path: &Path) -> Result<Harness> {
Copy link
Member

@jedel1043 jedel1043 Aug 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Again, I think all of these should just be private, and the user should be able to explore the repo using methods in Test, TestSuite, and friends.


impl Test {
/// Creates a new test.
pub fn new<N, C>(name: N, path: C, metadata: MetaData) -> color_eyre::Result<Self>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should not use eyre for error handling. We should have an Error enum that people can match on.

Copy link
Author

@PawelJastrzebski PawelJastrzebski left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for review @jedel1043

@@ -0,0 +1,24 @@
[package]
name = "tc39-test262"
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks like test262 it's available.

Comment on lines 20 to 29
pub fn clone_test262(commit: Option<&str>, verbose: u8) -> color_eyre::Result<()> {
const TEST262_REPOSITORY: &str = "https://github.com/tc39/test262";
git::clone(
TEST262_DIRECTORY,
TEST262_REPOSITORY,
&"origin/main",
commit,
verbose,
)
}
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Okey, that seams reasonable to me.

Comment on lines 26 to 52
pub(crate) trait RunTest<TO, TR> {
/// Runs the test.
fn run(&self, harness: &Harness, verbose: u8, optimizer_options: TO, console: bool) -> TR;

/// Runs the test once, in strict or non-strict mode
fn run_once(
&self,
harness: &Harness,
strict: bool,
verbose: u8,
optimizer_options: OptimizerOptions,
console: bool,
) -> TestResult;
}

pub(crate) trait RunTestSuite<TO, TR> {
/// Runs the test suite.
fn run(
&self,
harness: &Harness,
verbose: u8,
parallel: bool,
max_edition: SpecEdition,
optimizer_options: OptimizerOptions,
console: bool,
) -> SuiteResult;
}
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You are right, we can remove generics.

@jedel1043
Copy link
Member

Is this still being worked on? I assumed it was a WIP because you didn't re-request a review, but I'd be happy to review again if it is ready for that.

@PawelJastrzebski
Copy link
Author

Hi, @jedel1043,

Yes, it's still a work in progress. I haven’t had much time to work on it recently.

Could you take a quick look at tests/tester/src/main.rs? I have some doubts about the direction I've taken with the ReadResult enum.

If it looks good to you, I'll continue working on the error handling.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Split boa_tester into crates
2 participants