Skip to content
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

Small updates to system declaration #715

Open
wants to merge 27 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
aeaab99
Various small changes to Makefile to bring it inline with snovault an…
netsettler May 1, 2023
a9d842e
Merge branch 'master' into kmp_misc_20230501
netsettler May 1, 2023
aea0d66
Use poetry 1.4.2
netsettler May 1, 2023
660a881
Various kinds of cosmetics, but also use poetry 1.4.2
netsettler May 1, 2023
29a70ef
Mark questionably broken auth test as xfail.
netsettler May 1, 2023
d2e71a0
WIP
netsettler May 1, 2023
f2b532b
Remove dependency on py library.
netsettler May 2, 2023
31bb234
WIP. Won't lock.
netsettler May 2, 2023
b43fa55
Update classifiers in pyproject. Request dcicsnovault ^7.3.1. Specula…
netsettler May 2, 2023
627d775
Various changes in service of using new snovault beta.
netsettler May 3, 2023
8aa25b3
Update poetry lock file.
netsettler May 3, 2023
5050e05
builds and tests locally in python 3.9
netsettler May 16, 2023
195b5fb
Merge branch 'master' into kmp_misc_20230501_WIP
netsettler May 16, 2023
3fc96f9
Update version to prepare for beta.
netsettler May 16, 2023
f8cea01
Merge branch 'kmp_misc_20230501_WIP' into kmp_misc_20230501
netsettler May 17, 2023
bc6d34d
Merge branch 'kmp_remove_library' into kmp_misc_20230501
netsettler May 17, 2023
99a62fe
Changes to make Python 3.9 work with new dcicutils (with project supp…
netsettler May 22, 2023
296c7df
Update some mentions of proper python version.
netsettler May 24, 2023
40e4e89
Another testing candidate with latest snovault and utils betas included.
netsettler May 25, 2023
6a4e8f3
Take new dcicutils and snovault with project autoload.
netsettler May 27, 2023
815e27d
tests passing
willronchetti May 30, 2023
a6d1b36
update docker template ES URL
willronchetti May 31, 2023
f0272de
update utils, disable 3.8 testing
willronchetti May 31, 2023
e3f38d3
Merge branch 'master' into kmp_misc_20230501
netsettler Jun 13, 2023
cdb3ebb
Merge branch 'kmp_remove_library' into kmp_misc_20230501
netsettler Jun 13, 2023
747f740
Merge branch 'master' into kmp_misc_20230501
netsettler Jun 23, 2023
0152d0c
Consistent with master, remove loremipsum library. This got lost in a…
netsettler Jun 23, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ RUN apt-get update && apt-get upgrade -y && \
apt-get install -y --no-install-recommends vim emacs net-tools ca-certificates build-essential \
gcc zlib1g-dev postgresql-client libpq-dev git make curl libmagic-dev && \
pip install --upgrade pip && \
pip install poetry==1.3.2 && \
pip install poetry==1.4.2 && \
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/${NVM_VERSION}/install.sh | bash && \
. "$NVM_DIR/nvm.sh" && nvm install ${NODE_VERSION} && \
nvm use v${NODE_VERSION} && \
Expand Down
68 changes: 31 additions & 37 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -36,29 +36,20 @@ npm-setup: # runs all front-end setup
make aws-ip-ranges

moto-setup: # optional moto setup that must be done separately
@# This setup was needed here because there was no bracket syntax in pypoetry.com.
@# Now that we're using a higher version of moto, and not using the server parts, we don't need this here.
@# It's now all done in pyproject.toml, getting a higher version as well.
@# This comment and this make target can go away once that's proven effective. -kmp 23-Mar-2023
@# pip install "moto[server]==1.3.7"
@echo "'moto[server]' not being installed here. Regular 'moto' will be installed by pyproject.toml."

macpoetry-install: # Same as 'poetry install' except that on OSX Catalina, an environment variable wrapper is needed
macpoetry-install:
bin/macpoetry-install

configure: # does any pre-requisite installs
@#pip install --upgrade pip==21.0.1
pip install --upgrade pip
@#pip install poetry==1.1.9 # this version is known to work. -kmp 11-Mar-2021
@# Pin to version 1.1.15 for now to avoid this error:
@# Because encoded depends on wheel (>=0.29.0) which doesn't match any versions, version solving failed.
pip install poetry==1.3.2
pip install setuptools # ==57.5.0 # this version allows 2to3, any later will break -wrr 20-Sept-2021
pip install poetry==1.4.2
pip install setuptools # Allow versions after 57.5.0 now we're free of 2to3. -kmp 1-May-2023
pip install wheel
ifeq ($(shell uname -s), Darwin)
ifeq ($(shell uname -m), arm64)
pip install pysam=="0.21.0"
pip install matplotlib=="3.3.4"
pip install pysam=="0.21.0" # Must be kept consistent with version pinned in pyproject.toml
pip install matplotlib=="3.3.4" # Must be kept consistent with version pinned in pyproject.toml
endif
endif
poetry config virtualenvs.create false --local # do not create a virtualenv - the user should have already done this -wrr 20-Sept-2021
Expand All @@ -76,9 +67,12 @@ ifeq ($(shell uname -s), Darwin)
@echo "Looks like this is Mac so executing: make macbuild"
make macbuild
else
make anybuild
endif

anybuild:
make build-poetry
make build-after-poetry
endif

macbuild: # Builds for MacOS (see: bin/macpoetry-install)
make macbuild-poetry
Expand Down Expand Up @@ -157,11 +151,6 @@ kibana-start-test: # starts a test version of kibana (port chosen for active te
kibana-stop:
scripts/kibana-stop

kill: # kills back-end processes associated with the application. Use with care.
pkill -f postgres &
pkill -f elasticsearch &
pkill -f moto_server &

clean-python:
@echo -n "Are you sure? This will wipe all libraries installed on this virtualenv [y/N] " && read ans && [ $${ans:-N} = y ]
pip uninstall encoded
Expand All @@ -184,7 +173,6 @@ test:
@git log -1 --decorate | head -1
@date


BASE_MARKERS = not manual and not sloppy and not static and not broken
# Unit tests
NORM_MARKERS = not performance and not integratedx
Expand All @@ -194,35 +182,35 @@ PERF_MARKERS = performance and not integratedx
INTG_MARKERS = not performance and (integrated or integratedx)

retest:
poetry run python -m pytest -vv -r w --last-failed
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -vv -r w --last-failed

test-any:
poetry run python -m pytest -xvv -r w --timeout=200
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -xvv -r w --timeout=200

test-unit:
poetry run python -m pytest -xvv -r w --durations=25 --timeout=600 -m "${BASE_MARKERS} and ${NORM_MARKERS} and not indexing"
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -xvv -r w --durations=25 --timeout=600 -m "${BASE_MARKERS} and ${NORM_MARKERS} and not indexing"

test-unit-full:
poetry run python -m pytest -vv -r w --durations=25 --timeout=600 -m "${BASE_MARKERS} and ${NORM_MARKERS} and not indexing"
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -vv -r w --durations=25 --timeout=600 -m "${BASE_MARKERS} and ${NORM_MARKERS} and not indexing"

test-indexing-full:
make test-indexing-es-full
make test-indexing-not-es-full

test-indexing-es-full:
poetry run python -m pytest -vv -r w --durations=25 --timeout=300 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and es"
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -vv -r w --durations=25 --timeout=300 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and es"

test-indexing-not-es-full:
poetry run python -m pytest -vv -r w --durations=25 --timeout=300 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and not es"
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -vv -r w --durations=25 --timeout=300 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and not es"

test-indexing:
make test-indexing-es && make test-indexing-not-es

test-indexing-es:
poetry run python -m pytest -xvv -r w --durations=25 --timeout=200 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and es"
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -xvv -r w --durations=25 --timeout=200 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and es"

test-indexing-not-es:
poetry run python -m pytest -xvv -r w --durations=25 --timeout=200 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and not es"
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -xvv -r w --durations=25 --timeout=200 -m "${BASE_MARKERS} and ${NORM_MARKERS} and indexing and not es"

test-performance:
poetry run python -m pytest -xvv -r w --timeout=200 -m "${BASE_MARKERS} and ${PERF_MARKERS}"
Expand Down Expand Up @@ -259,16 +247,16 @@ remote-test-unit:
make remote-test-indexing-not-es

remote-test-not-indexing: # Note this only does the 'not indexing' tests
poetry run python -m pytest -xvv -r w --durations=25 --timeout=600 -m "${REMOTE_MARKERS} and not indexing" --aws-auth --es ${REMOTE_ES} --instafail --force-flaky --max-runs=2 --durations=20 --cov src/encoded
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -xvv -r w --durations=25 --timeout=600 -m "${REMOTE_MARKERS} and not indexing" --aws-auth --es ${REMOTE_ES} --instafail --force-flaky --max-runs=2 --durations=20 --cov src/encoded

remote-test-indexing:
make remote-test-indexing-es && make remote-test-not-indexing

remote-test-indexing-es:
poetry run python -m pytest -xvv -r w --durations=25 --timeout=300 -m "${REMOTE_MARKERS} and indexing and es" --aws-auth --es ${REMOTE_ES} --cov-append
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -xvv -r w --durations=25 --timeout=300 -m "${REMOTE_MARKERS} and indexing and es" --aws-auth --es ${REMOTE_ES} --cov-append

remote-test-indexing-not-es:
poetry run python -m pytest -xvv -r w --durations=25 --timeout=300 -m "${REMOTE_MARKERS} and indexing and not es" --aws-auth --es ${REMOTE_ES} --cov-append
SQLALCHEMY_WARN_20=1 poetry run python -m pytest -xvv -r w --durations=25 --timeout=300 -m "${REMOTE_MARKERS} and indexing and not es" --aws-auth --es ${REMOTE_ES} --cov-append

update: # updates dependencies
poetry update
Expand Down Expand Up @@ -329,12 +317,18 @@ tag-and-push-docker-production:
docker push ${AWS_ACCOUNT}.dkr.ecr.us-east-1.amazonaws.com/${ENV_NAME}:latest
date

kill: # kills back-end processes associated with the application. Use with care.
pkill -f postgres &
pkill -f elasticsearch &
pkill -f opensearch &
pkill -f moto_server &

lint-full:
@flake8 deploy/ || echo "flake8 failed for deploy/"
@flake8 src/encoded/ || echo "flake8 failed for src/encoded"
poetry run flake8 deploy/ || echo "flake8 failed for deploy/"
poetry run flake8 src/encoded/ || echo "flake8 failed for src/encoded/"

lint:
@flake8 deploy/ && flake8 src/encoded/
poetry run flake8 deploy/ && poetry run flake8 src/encoded/

help:
@make info
Expand All @@ -348,13 +342,13 @@ info:
$(info - Use 'make clean' to clear out (non-python) dependencies.)
$(info - Use 'make clean-python' to clear python virtualenv for fresh poetry install.)
$(info - Use 'make clear-poetry-cache' to clear the poetry pypi cache if in a bad state. (Safe, but later recaching can be slow.))
$(info - Use 'make configure' to install poetry. You should not have to do this directly.)
$(info - Use 'make configure' to install poetry, though 'make build' will do it automatically.)
$(info - Use 'make deploy1' to spin up postgres/elasticsearch and load inserts.)
$(info - Use 'make deploy2' to spin up the application server.)
$(info - Use 'make deploy3' to load variants and genes.)
$(info - Use 'make kibana-start' to start kibana on the default local ES port, and 'make kibana-stop' to stop it.)
$(info - Use 'make kibana-start-test' to start kibana on the port being used for active testing, and 'make kibana-stop' to stop it.)
$(info - Use 'make kill' to kill postgres and elasticsearch proccesses. Please use with care.)
$(info - Use 'make kill' to kill postgres and opensearch proccesses. Please use with care.)
$(info - Use 'make moto-setup' to install moto, for less flaky tests. Implied by 'make build'.)
$(info - Use 'make npm-setup' to build the front-end. Implied by 'make build'.)
$(info - Use 'make psql-dev' to start psql on data associated with an active 'make deploy1'.)
Expand Down
Loading