- Node installed at v14.0.0+
- Yarn 1 (classic yarn)
- Some dependencies may require compilation. On macOS, the Xcode Command Line Tools should be installed. On Ubuntu,
apt-get install build-essential
will install the required packages. Similar commands should work on other Linux distros. Windows will require some additional steps, see thenode-gyp
installation instructions for details.
SQLPad uses an automatic code formatter called Prettier and a linting tool called ESLint.
Run yarn run lint
after making any changes to code to check formatting and lint. Some formatting and lint may be fixed automatically by running yarn run fixlint
.
If using Visual Studio Code, Prettier and ESLint extensions can be installed to assist in detecting and fixing issues during development.
-
Clone/download this repo
-
Install dependencies and build the UI
scripts/build.sh
The gist of this script is:
# install root level dependencies using package-lock.json as reference yarn # install front-end dependencies using package-lock.json cd client yarn # build front-end yarn build # install back-end dependencies cd ../server yarn cd .. # copy client build to server directory mkdir server/public cp -r client/build/* server/public
At this point you can run the SQLPad server with the front-end built for production use:
cd server
node server.js --config ./config.dev.env
If preferred, SQLPad can be installed as a global module using the local files in this repo. This allows running SQLPad via the cli in any directory, just as if you had installed it with npm install sqlpad -g
. Note that you must build and copy the client prior to this step.
cd server
npm install -g
# Now from somewhere else you can run sqlpad like
cd ~
sqlpad --config ./config.dev.env
If sqlpad was installed globally via npm from npm, you may need to run npm uninstall sqlpad -g
.
A docker image may be built using the Dockerfile located in server
directory. See docker-publish.sh
for example docker build command.
Open 2 terminal sessions in the root of this repo.
In one session run the back end in development mode
cd server
yarn start
In the other start the development server for the front end.
cd client
yarn start
At this point you should have both back end and front end development servers running.
http://localhost:3000 serves React-based frontend in dev-mode
http://localhost:3010 serves frontend compiled for production
When viewing the front end in development mode, the page will automatically refresh on client file changes. The back end server will auto-restart on back end file changes as well.
When viewing SQLPad in dev-mode in port 3000, some features may not work correctly (like csv/xlsx downloads, google auth). This is likely due to the port difference in configuration (google auth can only redirect to 1 url/port) or the dev-mode proxy setup (React dev mode is served by a secondary web server that will proxy requests it doesn't understand to the SQLPad server running on 3010 during development.)
ESLint and Prettier are used to enforce code patterns and formatting in this project. A precommit hook should enforce and warn about these checks. If that is not set up however you may find these terminal commands useful.
# To check lint
yarn run lint
# To fix (some) errors and formatting automatically
yarn run fixlint
To run build/scripts.sh
on Windows, you may want to use an application like cmder. It will allow you to run scripts/build.sh
by calling sh
directly with sh scripts/build.sh
.
A Node.js script, server/generate-test-db-fixture.js
, can be used to generate a test sqlite database to be used for tests and local development. This replaces the previous mock driver implementation that was enabled when the debug
flag was turned on.
This test database allows for running SQL you likely know, instead of having to remember and use some variables set in SQL comments.
The script adds a sqlite database under server/test/fixtures/sales.sqlite
.
It can be used within SQLPad by creating a connection using the SQLite driver, and setting the filename to ./test/fixtures/sales.sqlite
.
The data in the database is somewhat nonsensical. It is also not randomized so that the results can be predictable. If you'd like to expand on this database, feel free.
SQLPad's test cases focus on the API server, with majority of tests being integration tests, with some unit tests sprinkled throughout.
Tests are located under server/test
directory, and use mocha
as a test runner. Tests may be run by running yarn test
within the server directory. For tests to run successfully, dependencies must be installed and the test database fixture generated.
cd server
# if dependencies have not yet been installed (build.sh will do this)
yarn
# If test fixture has not yet been generated (build.sh will do this)
node generate-test-db-fixture.js
# Start backend services if desired. (-d runs in background)
docker-compose up -d redis
docker-compose up -d ldap
# Run tests
yarn test
# If you are aiming to run a specific test case,
# you may do so using npx to call mocha,
# specifying the path to the test file and --exit to exit after tests have run
npx mocha test/path/to/file.js --exit
You can build and test the docker file by running the following from the root of the directory. Note that you must have Docker installed and running.
# build image from docker file
# to build for a different architecture you can do
# docker build -t localsqlpad . --no-cache=true --platform=linux/amd64
docker build -t localsqlpad .
# list images built
docker images
# Run localsqlpad image just built
# https://docs.docker.com/engine/reference/run/
docker run -p 3000:3000 -e "SQLPAD_ADMIN=admin@sqlpad.com" -e "SQLPAD_ADMIN_PASSWORD=admin" localsqlpad
# Now in browser you can open sqlpad at http://localhost:3000
In the event that a specific architecture needs to be tested, say an amd64 image to run on arm64, you can pull a dockerhub image based on specific sha.
docker run -p 3000:3000 -e "SQLPAD_ADMIN=admin@sqlpad.com" -e "SQLPAD_ADMIN_PASSWORD=admin" sqlpad/sqlpad@sha256:b80b4ab2af32ed07479d9233327bf3e5352fc71b41245d8e73b6403361be266a