This repo has been merged into circulation and removed as a submodule. All future development should be done in the circulation repo.
Default Branch: develop
This is the Server Core for Library Simplified. The server core contains functionality common between various LS servers, including database models and essential class constants, OPDS parsers, and certain configuration details.
The OA Content Server, Metadata Wrangler, and Circulation Manager all depend on this codebase. Treat it well.
Thorough deployment instructions, including essential libraries for Linux systems, can be found in the Library Simplified wiki. If this is your first time installing a Library Simplified repository, please review those instructions.
More often than not, this repository is installed and altered as part of another server using the following commands:
$ git submodule init # from inside one of the
$ git submodule update
$ cd core # make changes to core, as needed
Keep in mind that this workflow requires that any changes to the server core are committed and pushed independent to changes in the parent server.
Should you need to work on the core alone, use a traditional git workflow:
$ git clone [email protected]:NYPL/Simplified-server-core.git core
This project uses python 3 for development. You will need to set up a local virtual environment to install packages and run the project. Start by creating the virtual environment:
$ python3 -m venv env
Then include the database URLS as environment variables at the end in /env/bin/activate
. These databases should be created before this step and more information can be found in the Library Simplified wiki:
export SIMPLIFIED_PRODUCTION_DATABASE="postgres://simplified:[password]@localhost:5432/simplified_circulation_dev"
export SIMPLIFIED_TEST_DATABASE="postgres://simplified_test:[password]@localhost:5432/simplified_circulation_test"
Activate the virtual environment:
$ source env/bin/activate
and install the dependencies:
$ pip install -r requirements-dev.txt
Branch | Python Version |
---|---|
develop | Python 3 |
main | Python 3 |
python2 | Python 2 |
The default branch is develop
and that's the working branch that should be used when branching off for bug fixes or new features. Once a feature branch pull request is merged into develop
, the changes can be merged to main
to create releases.
Python 2 stopped being supported after January 1st, 2020 but there is still a python2
branch which can be used. As of May 2021, development will be done in the develop
and main
branches.
The Github Actions CI service runs the unit tests against Python 3.6, 3.7, 3.8 and 3.9 automatically using tox.
To run pytest
unit tests locally, install tox
.
pip install tox
Tox has an environment for each python version and an optional -docker
factor that will automatically use docker to
deploy service containers used for the tests. You can select the environment you would like to test with the tox -e
flag.
Environment | Python Version |
---|---|
py36 | Python 3.6 |
py37 | Python 3.7 |
py38 | Python 3.8 |
py39 | Python 3.9 |
All of these environments are tested by default when running tox. To test one specific environment you can use the -e
flag.
Test Python 3.8
tox -e py38
You need to have the Python versions you are testing against installed on your local system. tox
searches the system for installed Python versions, but does not install new Python versions. If tox
doesn't find the Python version its looking for it will give an InterpreterNotFound
errror.
Pyenv is a useful tool to install multiple Python versions, if you need to install missing Python versions in your system for local testing.
If you install tox-docker
tox will take care of setting up all the service containers necessary to run the unit tests
and pass the correct environment variables to configure the tests to use these services. Using tox-docker
is not required, but it is the recommended way to run the tests locally, since it runs the tests in the same way they are run on the Github Actions CI server.
pip install tox-docker
The docker functionality is included in a docker
factor that can be added to the environment. To run an environment
with a particular factor you add it to the end of the environment.
Test with Python 3.8 using docker containers for the services.
tox -e py38-docker
If you already have elastic search or postgres running locally, you can run them instead by setting the following environment variables:
SIMPLIFIED_TEST_DATABASE
SIMPLIFIED_TEST_ELASTICSEARCH
SIMPLIFIED_TEST_MINIO_ENDPOINT_URL
SIMPLIFIED_TEST_MINIO_USER
SIMPLIFIED_TEST_MINIO_PASSWORD
Make sure the ports and usernames are updated to reflect the local configuration.
# Set environment variables
export SIMPLIFIED_TEST_DATABASE="postgres://simplified_test:test@localhost:9005/simplified_circulation_test"
export SIMPLIFIED_TEST_ELASTICSEARCH="http://localhost:9006"
export SIMPLIFIED_TEST_MINIO_ENDPOINT_URL="http://localhost:9007"
export SIMPLIFIED_TEST_MINIO_USER="simplified"
export SIMPLIFIED_TEST_MINIO_PASSWORD="12345678901234567890"
# Run tox
tox -e py38
If you wish to pass additional arguments to pytest
you can do so through tox
. The default argument passed to pytest
is tests
, however you can override this. Every argument passed after a --
to the tox
command line will the passed
to pytest
, overriding the default.
Only run the test_cdn
tests with Python 3.6 using docker.
tox -e py36-docker -- tests/test_cdn.py
This project runs all the unit tests through Github Actions for new pull requests and when merging into the default develop
branch. The relevant file can be found in .github/workflows/test.yml
. When contributing updates or fixes, it's required for the test Github Action to pass for all python 3 environments. Run the tox
command locally before pushing changes to make sure you find any failing tests before committing them.
Copyright © 2015 The New York Public Library, Astor, Lenox, and Tilden Foundations
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.