X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=100dcdb6512de3820eeacd76cc3342f99c3f4288;hb=7137010b13dcede2f6efcff0be902e1676b40144;hp=12570b28b673f5d6eb8e1fdb8aaeb86753b39fa0;hpb=17c85d161444f91bc5a34eea4c4a150fe3927f4b;p=nepi.git diff --git a/Makefile b/Makefile index 12570b28..100dcdb6 100644 --- a/Makefile +++ b/Makefile @@ -1,10 +1,9 @@ SRCDIR = $(CURDIR)/src TESTDIR = $(CURDIR)/test -TESTLIB = $(TESTDIR)/lib +TESTLIB = $(TESTDIR)/lib BUILDDIR = $(CURDIR)/build DISTDIR = $(CURDIR)/dist -# stupid distutils, it's broken in so many ways SUBBUILDDIR = $(shell python -c 'import distutils.util, sys; \ print "lib.%s-%s" % (distutils.util.get_platform(), \ sys.version[0:3])') @@ -17,37 +16,40 @@ else BUILDDIR := $(BUILDDIR)/lib endif -#PYPATH = $(BUILDDIR):$(TESTLIB):$(PYTHONPATH) -PYPATH = "../nepi2/src:../nepi2/test/util:../netns/src" +PYPATH = $(BUILDDIR):$(TESTLIB):$(PYTHONPATH) COVERAGE = $(or $(shell which coverage), $(shell which python-coverage), \ coverage) -all: - ./setup.py build +all: clean + PYTHONPATH="$(PYTHONPATH):$(SRCDIR)" ./setup.py build install: all - ./setup.py install + PYTHONPATH="$(PYTHONPATH):$(SRCDIR)" ./setup.py install test: all retval=0; \ - for i in `find "$(TESTDIR)" -perm -u+x -type f`; do \ + for i in `find "$(TESTDIR)" -iname '*.py' -perm -u+x -type f`; do \ echo $$i; \ - TESTLIBPATH="$(TESTLIB)" PYTHONPATH="$(PYPATH)" $$i || retval=$$?; \ + PYTHONPATH="$(PYPATH)" $$i -v || retval=$$?; \ done; exit $$retval +test-one: all + echo $(file) $(case) + PYTHONPATH="$(PYPATH)" $(file) $(case) + coverage: all rm -f .coverage for i in `find "$(TESTDIR)" -perm -u+x -type f`; do \ set -e; \ - TESTLIBPATH="$(TESTLIB)" PYTHONPATH="$(PYPATH)" $(COVERAGE) -x $$i; \ + PYTHONPATH="$(PYPATH)" $(COVERAGE) -x $$i -v; \ done $(COVERAGE) -c $(COVERAGE) -r -m `find "$(BUILDDIR)" -name \\*.py -type f` rm -f .coverage clean: - ./setup.py clean rm -f `find -name \*.pyc` .coverage *.pcap + rm -rf "$(BUILDDIR)" distclean: clean rm -rf "$(DISTDIR)" @@ -62,3 +64,28 @@ dist: MANIFEST ./setup.py sdist .PHONY: all clean distclean dist test coverage install MANIFEST + +########## for uploading onto pypi +# this assumes you have an entry 'pypi' in your .pypirc +# see pypi documentation on how to create .pypirc +PYPI_TARGET=pypi +PYPI_TARBALL_HOST=root@build.onelab.eu +PYPI_TARBALL_TOPDIR=/build/nepi + +VERSIONTAG=$(shell cat VERSION) + +# run this only once the sources are in on the right tag +pypi: + setup.py sdist upload -r pypi + @if [ ssh $(PYPI_TARBALL_HOST) ls $(PYPI_TARBALL_TOPDIR)/nepi-$(VERSIONTAG).tar.gz ] ;\ + then echo "nepi-$(VERSIONTAG).tar.gz already present on $(PYPI_TARBALL_HOST) - ignored" ;\ + else rsync -av dist/nepi-$(VERSIONTAG).tar.gz $(PYPI_TARBALL_HOST):$(PYPI_TARBALL_TOPDIR)/ ;\ + fi + + +# it can be convenient to define a test entry, say testpypi +# 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