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

Document Asynchronous Configurations in the Config File's Docs #3733

Closed

Conversation

npetruzzelli
Copy link
Contributor

@npetruzzelli npetruzzelli changed the title Document Asynchronous Configurations in the Config File's Docs [WIP] Document Asynchronous Configurations in the Config File's Docs Dec 17, 2021
@npetruzzelli
Copy link
Contributor Author

npetruzzelli commented Dec 17, 2021

The default behavior of the server doesn't support promises, so some additional work will need to be done on the users side to get it working.

I need additional time to add that to this PR.


The changing the default behavior to support promises would be a breaking change.

@npetruzzelli npetruzzelli marked this pull request as draft December 17, 2021 20:56
@npetruzzelli npetruzzelli changed the title [WIP] Document Asynchronous Configurations in the Config File's Docs Document Asynchronous Configurations in the Config File's Docs Dec 30, 2021
@npetruzzelli npetruzzelli marked this pull request as ready for review December 30, 2021 17:48
@npetruzzelli
Copy link
Contributor Author

I looked, but didn't see a way to compile/serve the docs locally (maybe I missed something obvious?) so I'm not sure if I linked to from the config file page to the public api page correctly.

Otherwise this should be ready for review!

@devoto13
Copy link
Collaborator

@npetruzzelli The docs infra is located in the https://github.com/karma-runner/karma-runner.github.com repo. It's probably the easiest to copy your changes over to that repo and run grunt to spin up the local server. Note that you don't need to send a PR to that repo as we automatically sync changes from this repo as part of each release.

Copy link
Collaborator

@devoto13 devoto13 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 adding the docs! Left two comments, but I don't have a strong opinion about them.

docs/config/01-configuration-file.md Outdated Show resolved Hide resolved
docs/config/01-configuration-file.md Outdated Show resolved Hide resolved
@npetruzzelli
Copy link
Contributor Author

npetruzzelli commented Jan 2, 2022

Updated. I intentionally left out arrow functions and async/await. My thinking being that I want the focus to be on the use of promises. An experienced developer will already know to use those things (async/await) to simplify code, while a newer developer may be more anxious when seeing more unfamiliar things when they aren't required.

Is that acceptable?

Copy link
Collaborator

@devoto13 devoto13 left a comment

Choose a reason for hiding this comment

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

LGTM
Thanks!

@devoto13 devoto13 requested a review from jginsburgn January 2, 2022 19:18
@devoto13
Copy link
Collaborator

devoto13 commented Jan 2, 2022

@npetruzzelli Can you just squash into a single commit and remove the trailing "." from the commit message to make CI happy?

@npetruzzelli
Copy link
Contributor Author

I don't often manually squash or rebase, so I'm not sure I did it correctly.

@devoto13
Copy link
Collaborator

devoto13 commented Jan 2, 2022

@npetruzzelli No, does not look right, but no worries, I think @jginsburgn can squash when merging.

I usually can fix such issues myself, thanks to "Allow edits by maintainers" checkbox, but it does not seem to work in this case, because your fork is in the organisation. Or maybe I do something wrong. I think we can let it be for now.

Copy link
Member

@jginsburgn jginsburgn left a comment

Choose a reason for hiding this comment

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

@npetruzzelli please excuse my long delay in getting to this.

Can you please rebase and squash? If you don't remember how to squash, maybe you can give me push permissions to your fork?

}
```

If you are using the `parseConfig`method from the public API, then please see
Copy link
Member

Choose a reason for hiding this comment

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

Nit: missing space after parseConfig.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@jginsburgn - I will try to fix the typo and rebase/squash by this weekend.


module.exports = function configKarma(config) {
const myPreferredPort = 9876;
return findAvailablePort(myPreferredPort)
Copy link
Contributor

Choose a reason for hiding this comment

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

This is a bad example IMHO, because it leaves the door wide open for race conditions to occur.

Copy link
Contributor Author

@npetruzzelli npetruzzelli Feb 13, 2022

Choose a reason for hiding this comment

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

The most common (simplified) description of a race that I've had experience with is that multiple operations are being executed in parallel with no way to control the order of execution, which can lead to an unpredictable/unstable state.

I don't see the potential for race conditions here. The hypothetical findAvailablePort returns a promise. That promise must resolve before the onFulfilled parameter executes (which then executes config.set).

As long as it is a Promise instance, or an object that is a conforming implementation of Promises/A+, then the order of operations is controlled and there is no race.

Are you concerned about promise rejections not getting handled in the example?

Copy link
Contributor

Choose a reason for hiding this comment

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

I mean that getting a free port and then using that port. The port can be claimed by another process in the mean time.

I've experienced this twice on the past.

  1. On an old fashion buildserver that ran parallel builds.
  2. During mutation testing with StrykerJS, where we also need to spin up multiple test runner processes.

The right way to choose a free port is by leaving it undefined and letting karma itself choose it.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

That is reasonable. In the time it takes between getting a port number and starting the server, something else could claim the port, especially if other async tasks happen before then.

The example can easily be changed to another process that is often asynchronous, "getThingFromFileSystem" or "getThingFromNetwork". I would rather the example draw attention to "hey, this is asynchronous" instead of "this is a way to solve this specific problem/task" even if the intent was for illustration. I'd even be ok with the super generic "doAsyncThing", as long as it gets the point across that it returns a promise.

Copy link
Contributor

Choose a reason for hiding this comment

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

Exactly. I didn't see this PR at first and opened #3761 where I add documentation like that.

@npetruzzelli
Copy link
Contributor Author

I managed to make a mistake and accidentally closed this PR as a side effect of hard resetting my branch.

The new PR can be found here: #3762

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.

4 participants