mirror of
https://github.com/roleypoly/roleypoly.git
synced 2025-06-15 09:09:10 +00:00
big overhaul (#474)
* miniflare init * feat(api): add tests * chore: more tests, almost 100% * add sessions/state spec * add majority of routes and datapaths, start on interactions * nevermind, no interactions * nevermind x2, tweetnacl is bad but SubtleCrypto has what we need apparently * simplify interactions verify * add brute force interactions tests * every primary path API route is refactored! * automatically import from legacy, or die trying. * check that we only fetch legacy once, ever * remove old-src, same some historic pieces * remove interactions & worker-utils package, update misc/types * update some packages we don't need specific pinning for anymore * update web references to API routes since they all changed * fix all linting issues, upgrade most packages * fix tests, divorce enzyme where-ever possible * update web, fix integration issues * pre-build api * fix tests * move api pretest to api package.json instead of CI * remove interactions from terraform, fix deploy side configs * update to tf 1.1.4 * prevent double writes to worker in GCS, port to newer GCP auth workflow * fix api.tf var refs, upgrade node action * change to curl-based script upload for worker script due to terraform provider limitations * oh no, cloudflare freaked out :(
This commit is contained in:
parent
b644a38aa7
commit
3291f9aacc
183 changed files with 9853 additions and 9924 deletions
|
@ -1,9 +1,10 @@
|
|||
import { shallow } from 'enzyme';
|
||||
import { render } from '@testing-library/react';
|
||||
import * as React from 'react';
|
||||
import { ReactifyNewlines } from './ReactifyNewlines';
|
||||
|
||||
it('renders a correct number of divs per newlines', () => {
|
||||
const view = shallow(<ReactifyNewlines>{`1\n2\n3`}</ReactifyNewlines>);
|
||||
it('renders a correct number of divs per newlines', async () => {
|
||||
const view = render(<ReactifyNewlines>{`test\ntest\ntest`}</ReactifyNewlines>);
|
||||
|
||||
expect(view.find('div').length).toBe(3);
|
||||
const elements = await view.findAllByText('test');
|
||||
expect(elements.length).toBe(3);
|
||||
});
|
||||
|
|
26
packages/misc-utils/collection-tools.ts
Normal file
26
packages/misc-utils/collection-tools.ts
Normal file
|
@ -0,0 +1,26 @@
|
|||
export const difference = <T>(...arrays: T[][]) => {
|
||||
return arrays.reduce((a, b) => a.filter((v) => !b.includes(v)));
|
||||
};
|
||||
|
||||
export const groupBy = (arr: Record<string, any>[], key: string) => {
|
||||
return arr.reduce((r, a) => {
|
||||
r[a[key]] = [...r[a[key]], a];
|
||||
return r;
|
||||
}, {});
|
||||
};
|
||||
|
||||
export const keyBy = (arr: Record<string, any>[], key: string) => {
|
||||
return arr.reduce((r, a) => {
|
||||
r[a[key]] = a;
|
||||
return r;
|
||||
}, {});
|
||||
};
|
||||
|
||||
export const union = <T>(...arrays: T[][]) => {
|
||||
return arrays.reduce((a, b) => [...a, ...b]);
|
||||
};
|
||||
|
||||
export const isIdenticalArray = <T>(a1: T[], a2: T[]) => {
|
||||
// DEIs: http://stackoverflow.com/a/40496893/308645
|
||||
return a1.length === a2.length && a1.reduce((a, b) => a && a2.includes(b), true);
|
||||
};
|
10
packages/misc-utils/jest.config.js
Normal file
10
packages/misc-utils/jest.config.js
Normal file
|
@ -0,0 +1,10 @@
|
|||
module.exports = {
|
||||
preset: 'ts-jest/presets/js-with-ts',
|
||||
testEnvironment: 'jsdom',
|
||||
setupFilesAfterEnv: ['../../hack/jestSetup.ts'],
|
||||
globals: {
|
||||
'ts-jest': {
|
||||
tsconfig: '../../tsconfig.test.json',
|
||||
},
|
||||
},
|
||||
};
|
|
@ -1,11 +1,14 @@
|
|||
{
|
||||
"name": "@roleypoly/misc-utils",
|
||||
"version": "0.1.0",
|
||||
"scripts": {
|
||||
"test": "jest"
|
||||
},
|
||||
"dependencies": {
|
||||
"@roleypoly/types": "*"
|
||||
},
|
||||
"optionalDependencies": {
|
||||
"enzyme": "3.x",
|
||||
"@testing-library/react": "^12.1.2",
|
||||
"react": "*"
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue