-
Notifications
You must be signed in to change notification settings - Fork 49
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
Version 3 #470
Draft
ethanwu10
wants to merge
182
commits into
master
Choose a base branch
from
next
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Move configuration for TypeScript, configuration for NYC, and tests to inside of the server/ directory.
Hoist shared TS ESLint config options to project root Import from react / use react types to make typescript happy. Add prefresh config: Webpack 5 support for prefresh has not yet landed, but set up the configuration anyways.
Split lint script into separate server and client lint jobs, use `types` option in tsconfig to restrict global type loading, explicitly define `process.env` in client.
Roll back to Webpack 4 because Storybook does not support Webpack 5 for the near future (see storybookjs/storybook#11326 (comment)). Use @storybook/react (which includes React as a dependency) instead of Preact because the Storybook build breaks when using theme-ui (most likely because of the bundled React dependency).
Factor out Babel config to babel.config.js so Jest can also use it. Also set up globals handled by ProvidePlugin in Jest. @types/history@2 added as a dependency to force yarn to not hoist @types/history@^4.7 required by @types/reach__router, which is required by storybook somewhere. This ensures TypeScript resolves 'history' as @types/history@^4.7 instead of history@^5, which would otherwise happen if yarn hoisted @types/history.
Jest is running with TypeScript Babel preset to transpile server code and run against the TS sources; as a result, the leaderboard worker needed to be mocked out, since worker_process bypasses the transpiler.
Always run codecov collect step if the tests ran (regardless of success / failure), and run client tests too.
Codecov Report
@@ Coverage Diff @@
## master #470 +/- ##
==========================================
- Coverage 60.26% 51.35% -8.91%
==========================================
Files 87 89 +2
Lines 1384 1552 +168
Branches 57 300 +243
==========================================
- Hits 834 797 -37
- Misses 525 734 +209
+ Partials 25 21 -4
Continue to review full report at Codecov.
|
Use project references for server (source and test), and also pull shared config options up where possible.
Split config loading steps into individual exported functions; this allows for fine-grained control over config in tests by mocking the `load` module. Tests are set up to load config from its own conf.d, but inherit critical environment settings like database connections from the current (actual) config.
Use preact-render-to-string since preact-render-to-json does not actually render components in Preact X. Also add stories for navbar components.
Make client Jest config explicitly specifiy CWD for babel, so it can be run from any directory. Set top-level `test` script to use `--projects`, and also add a pre-commit hook to run Jest in only-changed mode.
Use mock factory to ensure config mocking works in all environments; this fixes crashes with the full app startup integration test (and therefore also fixes CI tests). Also add `--forceExit` to lint-staged command.
A few majors held back for another commit, Prettier re-run; theme-ui was upgraded with a breaking deprecation that will be fixed in the next commit.
`useCustomProperties` is now under `theme.config`.
Fix CI and Docker build to use yarn 2 commands, run `yarn dedupe` on pre-commit and CI, and update a few more configs for yarn 2 paths and conventions.
Disable diffs and auto merging on vendored yarn code, disable diffs on yarn.lock, and remove .yarn/sdks from repo.
Merge in changes to Fastify request log serializer from upstream Fastify. This fixes a deprecation warning.
Instead of using the object returned by `render`, query using the global `screen` as recommended by Kent C. Dodds. https://kentcdodds.com/blog/common-mistakes-with-react-testing-library#not-using-screen
Since the `getBy*` functions throw when they cannot find an element, prefer them for querying for elements that should exist (except when the test is explicitly for whether or not the element exists). This removes most of the null checks in the test code.
Since yarn 2 uses an internal shell parser[1] which supports environment variables, we no longer need to use cross-env for cross-platform environment variable setting. [1]: https://github.com/yarnpkg/berry/tree/%40yarnpkg/shell%2F2.4.1/packages/yarnpkg-shell
Fix .yarn being included twice, add dockerignore entries for yarn to hopefully prevent some churn (using the ignore list recommended for PnP zero-install).
When casting the handler functions exported from individual routes, derive the target type by inspecting the `route` method of the FastifyInstance we are registering them on. Since we adjust the instance type to better match `http.Server`, this fixes a type mismatch that appears when compiling on some platforms when trying to register the handlers.
migrate to yarn 2 + batch dependency upgrade
Break ties between users with solves on challenges not marked `tiebreakEligible: false` the same, but also rank users with only solves on challenges marked `tiebreakEligible: false` via solve times on those challenges. This does not change existing rankings, but adds users with only solves on these challenges to the leaderboard as well. Co-authored-by: Philip Papurt <ginkoid@gmail.com>
Remove intermediate calculation bookkeeping data from the types returned out of the leaderboard worker. This change also strips the data from the objects, resulting in the creation of a new JS object per leaderboard entry, but keeps snapshots cleaner. We may wish to consider doing this in only snapshot serialization in the future.
Small refactor of implementation of leaderboard cache `getRange` to leverage type narrowing on the range parameters to eliminate a pair of casts. Also restrict the `all` parameter to `true` only.
chore: cherry-pick changes from master
refactor(server): leverage narrowing on cache typing
chore: backport ranking users with only tiebreakEligible: false
`fastify-static`'s types have been fixed, making the previous cast unnecessary now; remove it.
Previously `endTime` was set to 2021-06-10, which is now in the past and causing tests regarding flag submission to fail since the CTF is now closed. Year 3000 should be good enough right?
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Major codebase refactor / client rewrite
Draft PR for CI runs
Closes #424