X-Git-Url: http://git.onelab.eu/?p=nepi.git;a=blobdiff_plain;f=Makefile;h=4629ec7018fc3730a31d4bc391bbb924710a6b71;hp=74a1a10fa507f9ff6b279a0d02f710cc6645123b;hb=83880a4c0856307dc617da9e75a49cf64bf78cbf;hpb=b7963a4f2a039a28a9dd8fd9a8393b5373968887 diff --git a/Makefile b/Makefile index 74a1a10f..4629ec70 100644 --- a/Makefile +++ b/Makefile @@ -1,41 +1,43 @@ +PYTHON = python SRCDIR = $(CURDIR)/src TESTDIR = $(CURDIR)/test TESTLIB = $(TESTDIR)/lib -BUILDDIR = $(CURDIR)/build +BUILDDIR = $(CURDIR)/build/lib DISTDIR = $(CURDIR)/dist -SUBBUILDDIR = $(shell python -c 'import distutils.util, sys; \ - print "lib.%s-%s" % (distutils.util.get_platform(), \ - sys.version[0:3])') -PYTHON25 := $(shell python -c 'import sys; v = sys.version_info; \ - print (1 if v[0] <= 2 and v[1] <= 5 else 0)') - -ifeq ($(PYTHON25),0) -BUILDDIR := $(BUILDDIR)/$(SUBBUILDDIR) -else -BUILDDIR := $(BUILDDIR)/lib -endif - PYPATH = $(BUILDDIR):$(TESTLIB):$(PYTHONPATH) COVERAGE = $(or $(shell which coverage), $(shell which python-coverage), \ coverage) all: clean - PYTHONPATH="$(PYTHONPATH):$(SRCDIR)" ./setup.py build + PYTHONPATH="$(PYTHONPATH):$(SRCDIR)" $(PYTHON) ./setup.py build install: all - PYTHONPATH="$(PYTHONPATH):$(SRCDIR)" ./setup.py install + PYTHONPATH="$(PYTHONPATH):$(SRCDIR)" $(PYTHON) ./setup.py install test: all retval=0; \ for i in `find "$(TESTDIR)" -iname '*.py' -perm -u+x -type f`; do \ echo $$i; \ - PYTHONPATH="$(PYPATH)" $$i -v || retval=$$?; \ + PYTHONPATH="$(PYPATH)" $(PYTHON) $$i -v || retval=$$?; \ done; exit $$retval +ifeq ($(file),) +test-one: + echo Run $(make) $@ file=test/some/path +else test-one: all echo $(file) $(case) - PYTHONPATH="$(PYPATH)" $(file) $(case) + PYTHONPATH="$(PYPATH)" $(PYTHON) $(file) $(case) +endif + + +all-tests: test-app test-node + +test-app: + $(MAKE) test-one file=test/resources/linux/application.py case=$(case) +test-node: + $(MAKE) test-one file=test/resources/linux/node.py case=$(case) coverage: all rm -f .coverage @@ -48,7 +50,7 @@ coverage: all rm -f .coverage clean: - rm -f `find -name \*.pyc` .coverage *.pcap + rm -f $$(find . -name '*.pyc') .coverage *.pcap rm -rf "$(BUILDDIR)" distclean: clean @@ -68,8 +70,17 @@ dist: MANIFEST ########## for uploading onto pypi # this assumes you have an entry 'pypi' in your .pypirc # see pypi documentation on how to create .pypirc +LOCAL_ID=$(shell id) +ifneq "$(LOCAL_ID)" "$(filter $(LOCAL_ID),parmen)" +BUILD_ID=thierry +USE_TWINE= +else +BUILD_ID=mario +USE_TWINE=true +endif + PYPI_TARGET=pypi -PYPI_TARBALL_HOST=root@build.onelab.eu +PYPI_TARBALL_HOST=$(BUILD_ID)@build.onelab.eu PYPI_TARBALL_TOPDIR=/build/nepi VERSION=$(shell cat VERSION) @@ -77,15 +88,20 @@ VERSIONTAG=nepi-$(VERSION)-pypi VERSIONTAR=nepi-$(VERSION).tar.gz ALREADY_SET=$(shell git tag | grep '^$(VERSIONTAG)$$') +########## +# depending on the value of USE_TWINE, we either do the upload with setup.py itself, +# or with the help of twine which apparently is the only way that mario could find out on his setup +define upload_pypi +$(if $(USE_TWINE),./setup.py sdist && twine upload dist/* -r $(1),./setup.py sdist upload -r $(1)) +endef + # run this only once the sources are in on the right tag pypi: @echo "Have you committed all changes (type Ctrl-c if not) ? " ; read _ @if [ -n "$(ALREADY_SET)" ] ; then echo "tag $(VERSIONTAG) already set"; false; fi @echo "You are about to release $(VERSION) - OK (Ctrl-c if not) ? " ; read _ git tag $(VERSIONTAG) - #./setup.py sdist upload -r pypi - ./setup.py sdist - twine upload dist/* -r pypi + $(call upload_pypi,pypi) @if [ ssh $(PYPI_TARBALL_HOST) ls $(PYPI_TARBALL_TOPDIR)/$(VERSIONTAR) ] ;\ then echo "$(VERSIONTAR) already present on $(PYPI_TARBALL_HOST) - ignored" ;\ else rsync -av dist/$(VERSIONTAR) $(PYPI_TARBALL_HOST):$(PYPI_TARBALL_TOPDIR)/ ;\ @@ -96,7 +112,15 @@ pypi: # that points at the testpypi public site # in this case we do not want to upload anything on the build box though -testpypi: - #./setup.py sdist upload -r testpypi - ./setup.py sdist - twine upload dist/* -r testpypi +testpypi: + $(call upload_pypi,testpypi) + +#################### convenience, for debugging only +# make +foo : prints the value of $(foo) +# make ++foo : idem but verbose, i.e. foo=$(foo) +++%: varname=$(subst +,,$@) +++%: + @echo "$(varname)=$($(varname))" ++%: varname=$(subst +,,$@) ++%: + @echo "$($(varname))"