mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-04-26 10:26:15 -04:00

Also add symlinks from the old `bin/` and `tests/` locations to avoid breaking scripts and other tools. Motivations: * Scripts and tests no longer have to do dubious things like: require('ep_etherpad-lite/node_modules/foo') to access packages installed as dependencies in `src/package.json`. * Plugins can access the backend test helper library in a non-hacky way: require('ep_etherpad-lite/tests/backend/common') * We can delete the top-level `package.json` without breaking our ability to lint the files in `bin/` and `tests/`. Deleting the top-level `package.json` has downsides: It will cause `npm` to print warnings whenever plugins are installed, npm will no longer be able to enforce a plugin's peer dependency on ep_etherpad-lite, and npm will keep deleting the `node_modules/ep_etherpad-lite` symlink that points to `../src`. But there are significant upsides to deleting the top-level `package.json`: It will drastically speed up plugin installation because `npm` doesn't have to recursively walk the dependencies in `src/package.json`. Also, deleting the top-level `package.json` avoids npm's horrible dependency hoisting behavior (where it moves stuff from `src/node_modules/` to the top-level `node_modules/` directory). Dependency hoisting causes numerous mysterious problems such as silent failures in `npm outdated` and `npm update`. Dependency hoisting also breaks plugins that do: require('ep_etherpad-lite/node_modules/foo')
36 lines
1.1 KiB
Bash
Executable file
36 lines
1.1 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
#sending changesets every 101ms should not trigger ratelimit
|
|
node send_changesets.js http://127.0.0.1:8081/p/BACKEND_TEST_ratelimit_101ms 101
|
|
if [[ $? -ne 0 ]];then
|
|
echo "FAILED: ratelimit was triggered when sending every 101 ms"
|
|
exit 1
|
|
fi
|
|
|
|
#sending changesets every 99ms should trigger ratelimit
|
|
node send_changesets.js http://127.0.0.1:8081/p/BACKEND_TEST_ratelimit_99ms 99
|
|
if [[ $? -ne 1 ]];then
|
|
echo "FAILED: ratelimit was not triggered when sending every 99 ms"
|
|
exit 1
|
|
fi
|
|
|
|
#sending changesets every 101ms via proxy
|
|
node send_changesets.js http://127.0.0.1:8081/p/BACKEND_TEST_ratelimit_101ms 101 &
|
|
pid1=$!
|
|
|
|
#sending changesets every 101ms via second IP and proxy
|
|
docker exec anotherip node /tmp/send_changesets.js http://172.23.42.1:80/p/BACKEND_TEST_ratelimit_101ms_via_second_ip 101 &
|
|
pid2=$!
|
|
|
|
wait $pid1
|
|
exit1=$?
|
|
wait $pid2
|
|
exit2=$?
|
|
|
|
echo "101ms with proxy returned with ${exit1}"
|
|
echo "101ms via another ip returned with ${exit2}"
|
|
|
|
if [[ $exit1 -eq 1 || $exit2 -eq 1 ]];then
|
|
echo "FAILED: ratelimit was triggered during proxy and requests via second ip"
|
|
exit 1
|
|
fi
|