Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.buildout
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
6
Merge Requests
6
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
slapos.buildout
Commits
58125125
Commit
58125125
authored
Feb 16, 2017
by
Jim Fulton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added tests for the getting-started examples
But getting failures when running with some other tests. Weird.
parent
5f13f044
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
209 additions
and
15 deletions
+209
-15
doc/getting-started.rst
doc/getting-started.rst
+135
-9
setup.py
setup.py
+2
-1
src/zc/buildout/tests.py
src/zc/buildout/tests.py
+72
-5
No files found.
doc/getting-started.rst
View file @
58125125
...
...
@@ -36,11 +36,31 @@ a minimal configuration::
[
buildout
]
parts
=
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
A
minimal
(
and
useless
)
Buildout
configuration
has
a
``
buildout
``
section
with
a
parts
option
.
If
we
run
Buildout
::
buildout
..
->
src
>>>
run_buildout
(
src
)
>>>
import
os
>>>
ls
=
lambda
d
=
'.'
:
os
.
listdir
(
d
)
>>>
eqs
(
ls
(),
'buildout.cfg'
,
'bin'
,
'eggs'
,
'develop-eggs'
,
'parts'
)
>>>
eqs
(
ls
(
'bin'
))
>>>
eqs
(
ls
(
'develop-eggs'
))
>>>
eqs
(
ls
(
'parts'
))
TODO
:
fix
upgrading
so
eggs
is
empty
>>>
nope
(
'ZEO'
in
ls
(
'eggs'
))
Four
directories
are
created
:
bin
...
...
@@ -86,6 +106,10 @@ update our Buildout configuration to add a ``zeo`` part::
recipe
=
zc
.
recipe
.
egg
eggs
=
ZEO
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
We
added
the
part
name
,
``
zeo
``
to
the
``
parts
``
option
in
the
``
buildout
``
section
.
We
also
added
a
``
zeo
``
section
with
two
options
:
...
...
@@ -110,6 +134,10 @@ If we run this [#gcc]_::
buildout
.. -> src
>>> run_buildout(src)
Then a number of things will happen:
- ``zc.recipe.egg`` will be downloaded and installed in your ``eggs``
...
...
@@ -136,6 +164,11 @@ Then a number of things will happen:
drwxr-xr-x 4 jim staff 136 Feb 15 13:06 zodbpickle-0.6.0-py3.5-macosx-10.10-x86_64.egg
drwxr-xr-x 4 jim staff 136 Feb 15 13:06 zope.interface-4.3.3-py3.5-macosx-10.10-x86_64.egg
.. ZEO in eggs:
>>> yup([n for n in ls('
eggs
') if n.startswith('
ZEO
-
4.3.1
-
')])
- A number of scripts will be installed in the ``bin`` directory::
bash-3.2$ ls -l bin
...
...
@@ -144,10 +177,13 @@ Then a number of things will happen:
-rwxr-xr-x 1 jim staff 861 Feb 15 13:07 zeo-nagios
-rwxr-xr-x 1 jim staff 861 Feb 15 13:07 zeoctl
-rwxr-xr-x 1 jim staff 879 Feb 15 13:07 zeopack
-rwxr-xr-x 1 jim staff 867 Feb 15 13:07 zeopasswd
One in particular, ``runzeo`` is used to run a ZEO server.
.. Really?
>>> yup('
runzeo
' in ls('
bin
'))
Generating configuration and custom scripts
===========================================
...
...
@@ -172,6 +208,10 @@ configuration becomes::
-
f
${
buildout
:
directory
}/
data
.
fs
-
a
127.0.0.1
:
8200
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
Here
we
've added a new ``server`` part that uses ``zc.zdaemonrecipe``.
We used a ``program`` option to define what program should be run.
There are a couple of interesting things to note about this option:
...
...
@@ -203,6 +243,10 @@ If we run Buildout::
buildout
..
->
src
>>>
run_buildout
(
src
)
-
The
``
zc
.
zdaemonrecipe
``
recipe
will
be
downloaded
and
installed
in
the
eggs
directory
.
...
...
@@ -235,6 +279,11 @@ If we run Buildout::
</
logfile
>
</
eventlog
>
..
->
expect
>>>
expect
=
expect
.
replace
(
'/Users/jim/t/0214'
,
os
.
getcwd
()).
strip
()
>>>
eq
(
expect
,
read
(
'parts/server/zdaemon.conf'
).
strip
())
The
**
details
aren
't important**, other than the fact that the
configuration file reflects part options and the actual buildout
location.
...
...
@@ -320,6 +369,10 @@ Buildout to *not* check for newer versions of Python requirements::
buildout
-
N
..
->
src
>>>
run_buildout
(
src
)
This
relaxes
repeatability
,
but
with
little
risk
if
there
was
a
recent
run
without
this
option
.
...
...
@@ -333,6 +386,22 @@ where you list them, as in::
recipe
=
zc
.
recipe
.
egg
eggs
=
ZEO
<
5.0
..
->
src
>>>
prefix
=
"""
... [buildout]
... parts = zeo
... """
>>>
with
open
(
'buildout.cfg'
,
'w'
)
as
f
:
...
_
=
f
.
write
(
prefix
)
...
_
=
f
.
write
(
src
)
>>>
import
shutil
>>>
shutil
.
rmtree
(
'eggs'
)
>>>
run_buildout
(
'buildout show-picked-versions=true'
,
debug
=
'o'
)
>>>
yup
([
n
for
n
in
ls
(
'eggs'
)
if
n
.
startswith
(
'ZEO-4.3.1-'
)])
>>>
yup
(
'ZEO = 4.3.1'
in
read
(
'o'
))
In
this
example
,
we
've requested a version of ZEO less than 5.0.
The more common way to pin version is using a ``versions`` section::
...
...
@@ -352,7 +421,15 @@ The more common way to pin version is using a ``versions`` section::
-a 127.0.0.1:8200
[versions]
ZEO = 5.0.4
ZEO = 4.3.1
.. -> src
>>> write(src, '
buildout
.
cfg
')
>>> shutil.rmtree('
eggs
')
>>> run_buildout('
buildout
show
-
picked
-
versions
=
true
', debug='
o
')
>>> yup([n for n in ls('
eggs
') if n.startswith('
ZEO
-
4.3.1
-
')])
>>> nope('
ZEO
=
4.3.1
' in read('
o
'))
Larger projects may need to pin many versions, so it'
s
common
to
put
versions
in
their
own
file
::
...
...
@@ -372,6 +449,10 @@ versions in their own file::
-
f
${
buildout
:
directory
}/
data
.
fs
-
a
127.0.0.1
:
8200
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
Here
,
we
've used the Buildout ``extends`` option to say that
configurations should be read from the named file (or files) and that
configuration in the current file should override configuration in the
...
...
@@ -379,12 +460,19 @@ extended files. To continue the example, our ``versions.cfg`` file
might look like::
[versions]
ZEO = 5.0.4
ZEO = 4.3.1
.. -> versions_cfg
>>> write(versions_cfg, '
versions
.
cfg
')
>>> shutil.rmtree('
eggs
')
>>> run_buildout('
buildout
show
-
picked
-
versions
=
true
', debug='
o
')
>>> yup([n for n in ls('
eggs
') if n.startswith('
ZEO
-
4.3.1
-
')])
>>> nope('
ZEO
=
4.3.1
' in read('
o
'))
We can use the ``update-versions-file`` option to ask Buildout to
maintain our ``versions.cfg`` file for us::
[buildout]
extends = versions.cfg
show-picked-versions = true
...
...
@@ -403,6 +491,14 @@ maintain our ``versions.cfg`` file for us::
-f ${buildout:directory}/data.fs
-a 127.0.0.1:8200
.. -> src
>>> write(src, '
buildout
.
cfg
')
>>> eq(versions_cfg, read('
versions
.
cfg
'))
>>> run_buildout('
buildout
show
-
picked
-
versions
=
true
', debug='
o
')
>>> yup([n for n in ls('
eggs
') if n.startswith('
ZEO
-
4.3.1
-
')])
>>> yup('
ZODB
=
' in read('
versions
.
cfg
'))
With ``update-versions-file``, whenever Buildout gets the newest
version for a requirement (subject to requirement constraints), it
appends the version to the named file, along with a comment saying
...
...
@@ -440,20 +536,27 @@ Buildout versions and automatic upgrade
In the interest of repeatability, Buildout can upgrade itself or its
dependencies to use the newest versions or downgrade to respect pinned
versions. This only happens if you run Buildout from a buildout'
s
own
``
bin
``
directory
.
If
you
've been running the examples, you may have
noticed the message::
Not upgrading because not running a local buildout command.
``
bin
``
directory
.
We
can
use
Buildout
's ``bootstrap`` command to install a local
buildout script::
buildout bootstrap
.. -> src
>>> nope('
buildout
' in ls('
bin
'))
>>> run_buildout(src)
>>> yup('
buildout
' in ls('
bin
'))
Then, if the installed script is used::
bin/buildout
.. -> src
>>> yup(os.path.exists(src.strip()))
Then Buildout will upgrade or downgrade to be consistent with version
requirements. See the :doc:`bootstrapping topic
<topics/bootstrapping>` to learn more about bootstrapping.
...
...
@@ -469,6 +572,8 @@ facilitates this with the ``develop`` option::
develop = .
...
.. -> develop_snippet
The ``develop`` option takes one more more paths to project `setup.py
<https://docs.python.org/3.6/distutils/setupscript.html>`_ files or,
more commonly, directories containing them. Buildout then creates
...
...
@@ -496,7 +601,11 @@ Fortunately, an application setup script can be minimal. Here's an
example::
from setuptools import setup
setup
(
name
=
'main'
,
install_requires
=
[
'bobo'
,
'WebTest'
])
setup(name='
main
', install_requires = ['
ZODB
', '
six
'])
.. -> src
>>> write(src, '
setup
.
py
')
We suggest copying and modifying the example above, using it as
boilerplate. As is probably clear, the setup arguments used:
...
...
@@ -523,6 +632,15 @@ something like this::
eggs
=
main
interpreter
=
py
..
->
src
>>>
eq
(
src
.
strip
().
split
(
'\n'
)[:
2
],
develop_snippet
.
strip
().
split
(
'\n'
)[:
2
])
>>>
write
(
src
,
'buildout.cfg'
)
>>>
run_buildout
(
debug
=
'o'
)
>>>
yup
(
'Develop: '
in
read
(
'o'
))
>>>
eq
(
os
.
getcwd
(),
read
(
'develop-eggs/main.egg-link'
).
split
()[
0
])
There
's a new option, ``interpreter``, which names an *interpreter*
script to be generated. An interpreter script [#interpreter-script]_
mimics a Python interpreter with its path set to include the
...
...
@@ -531,10 +649,18 @@ dependencies. We can run the interpreter::
bin/py
.. -> path
>>> yup(os.getcwd() in read(path.strip()))
To get an interactive Python prompt, or you can run a script with it::
bin/py somescript.py
.. -> path
>>> yup(os.path.exists(path.split()[0]))
If you need to work on multiple interdependent projects at the same
time, you can name multiple directories in the ``develop`` option,
typically pointing to multiple check outs. A popular Buildout
...
...
setup.py
View file @
58125125
...
...
@@ -92,7 +92,8 @@ setup(
],
include_package_data
=
True
,
entry_points
=
entry_points
,
extras_require
=
dict
(
test
=
[
'zope.testing'
,
'manuel'
]),
extras_require
=
dict
(
test
=
[
'zope.testing'
,
'manuel'
,
'ZEO ==4.3.1'
,
'zc.zdaemonrecipe'
]),
zip_safe
=
False
,
classifiers
=
[
'Intended Audience :: Developers'
,
...
...
src/zc/buildout/tests.py
View file @
58125125
...
...
@@ -13,7 +13,7 @@
#
##############################################################################
from
zc.buildout.buildout
import
print_
from
zope.testing
import
renormalizing
from
zope.testing
import
renormalizing
,
setupstack
import
doctest
import
manuel.capture
...
...
@@ -3375,10 +3375,14 @@ def updateSetup(test):
makeNewRelease
(
dist
.
key
,
ws
,
new_releases
)
os
.
mkdir
(
os
.
path
.
join
(
new_releases
,
dist
.
key
))
bootstrap_py
=
os
.
path
.
join
(
os
.
path
.
dirname
(
os
.
path
.
dirname
(
os
.
path
.
dirname
(
os
.
path
.
dirname
(
__file__
)))),
'bootstrap'
,
'bootstrap.py'
)
def
ancestor
(
path
,
level
):
while
level
>
0
:
path
=
os
.
path
.
dirname
(
path
)
level
-=
1
return
path
bootstrap_py
=
os
.
path
.
join
(
ancestor
(
__file__
,
4
),
'bootstrap'
,
'bootstrap.py'
)
def
bootstrapSetup
(
test
):
buildout_txt_setup
(
test
)
...
...
@@ -3402,6 +3406,21 @@ normalize_S = (
'#!/usr/local/bin/python2.7'
,
)
def
run_buildout
(
command
,
debug
):
import
sys
if
debug
:
if
isinstance
(
debug
,
str
):
sys
.
stdout
=
sys
.
stderr
=
open
(
debug
,
'w'
)
else
:
sys
.
stdout
=
sys
.
stderr
else
:
sys
.
stderr
=
sys
.
stdout
args
=
command
.
strip
().
split
()
import
pkg_resources
buildout
=
pkg_resources
.
load_entry_point
(
'zc.buildout'
,
'console_scripts'
,
args
[
0
])
buildout
(
args
[
1
:])
def
test_suite
():
test_suite
=
[
manuel
.
testing
.
TestSuite
(
...
...
@@ -3663,6 +3682,54 @@ def test_suite():
'
testing_bugfix
.
txt
'),
]
docdir = os.path.join(ancestor(__file__, 4), '
doc
')
if os.path.exists(docdir) and not sys.platform.startswith('
win
'):
# Note that the purpose of the documentation tests are mainly
# to test the documentation, not to test buildout.
def docSetUp(test):
index=" index=" + os.path.join(ancestor(__file__, 4), '
doc
')
def run_buildout_in_process(command='
buildout
', debug=False):
from multiprocessing import Process, Queue
queue = Queue()
process = Process(
target=run_buildout,
args=(command + index, debug),
)
process.daemon = True
process.start()
process.join(9)
assert not process.is_alive()
return process.exitcode or None
def read(path):
with open(path) as f:
return f.read()
def write(text, path):
with open(path, '
w
') as f:
f.write(text)
test.globs.update(
indexarg=index,
run_buildout=run_buildout_in_process,
yup=lambda cond, orelse='
Nope
': None if cond else orelse,
nope=lambda cond, orelse='
Nope
': orelse if cond else None,
eq=lambda a, b: None if a == b else (a, b),
eqs=lambda a, *b: None if set(a) == set(b) else (a, b),
read=read,
write=write,
)
setupstack.setUpDirectory(test)
test_suite.append(
manuel.testing.TestSuite(
manuel.doctest.Manuel() + manuel.capture.Manuel(),
os.path.join(docdir, '
getting
-
started
.
rst
'),
setUp=docSetUp, tearDown=setupstack.tearDown
))
# adding bootstrap.txt doctest to the suite
# only if bootstrap.py is present
if os.path.exists(bootstrap_py):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment