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::
...
@@ -36,11 +36,31 @@ a minimal configuration::
[
buildout
]
[
buildout
]
parts
=
parts
=
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
A
minimal
(
and
useless
)
Buildout
configuration
has
a
``
buildout
``
section
A
minimal
(
and
useless
)
Buildout
configuration
has
a
``
buildout
``
section
with
a
parts
option
.
If
we
run
Buildout
::
with
a
parts
option
.
If
we
run
Buildout
::
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
:
Four
directories
are
created
:
bin
bin
...
@@ -86,6 +106,10 @@ update our Buildout configuration to add a ``zeo`` part::
...
@@ -86,6 +106,10 @@ update our Buildout configuration to add a ``zeo`` part::
recipe
=
zc
.
recipe
.
egg
recipe
=
zc
.
recipe
.
egg
eggs
=
ZEO
eggs
=
ZEO
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
We
added
the
part
name
,
``
zeo
``
to
the
``
parts
``
option
in
the
We
added
the
part
name
,
``
zeo
``
to
the
``
parts
``
option
in
the
``
buildout
``
section
.
We
also
added
a
``
zeo
``
section
with
two
``
buildout
``
section
.
We
also
added
a
``
zeo
``
section
with
two
options
:
options
:
...
@@ -110,6 +134,10 @@ If we run this [#gcc]_::
...
@@ -110,6 +134,10 @@ If we run this [#gcc]_::
buildout
buildout
.. -> src
>>> run_buildout(src)
Then a number of things will happen:
Then a number of things will happen:
- ``zc.recipe.egg`` will be downloaded and installed in your ``eggs``
- ``zc.recipe.egg`` will be downloaded and installed in your ``eggs``
...
@@ -136,6 +164,11 @@ Then a number of things will happen:
...
@@ -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 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
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::
- A number of scripts will be installed in the ``bin`` directory::
bash-3.2$ ls -l bin
bash-3.2$ ls -l bin
...
@@ -144,10 +177,13 @@ Then a number of things will happen:
...
@@ -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 zeo-nagios
-rwxr-xr-x 1 jim staff 861 Feb 15 13:07 zeoctl
-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 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.
One in particular, ``runzeo`` is used to run a ZEO server.
.. Really?
>>> yup('
runzeo
' in ls('
bin
'))
Generating configuration and custom scripts
Generating configuration and custom scripts
===========================================
===========================================
...
@@ -172,6 +208,10 @@ configuration becomes::
...
@@ -172,6 +208,10 @@ configuration becomes::
-
f
${
buildout
:
directory
}/
data
.
fs
-
f
${
buildout
:
directory
}/
data
.
fs
-
a
127.0.0.1
:
8200
-
a
127.0.0.1
:
8200
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
Here
we
've added a new ``server`` part that uses ``zc.zdaemonrecipe``.
Here
we
've added a new ``server`` part that uses ``zc.zdaemonrecipe``.
We used a ``program`` option to define what program should be run.
We used a ``program`` option to define what program should be run.
There are a couple of interesting things to note about this option:
There are a couple of interesting things to note about this option:
...
@@ -203,6 +243,10 @@ If we run Buildout::
...
@@ -203,6 +243,10 @@ If we run Buildout::
buildout
buildout
..
->
src
>>>
run_buildout
(
src
)
-
The
``
zc
.
zdaemonrecipe
``
recipe
will
be
downloaded
and
installed
in
-
The
``
zc
.
zdaemonrecipe
``
recipe
will
be
downloaded
and
installed
in
the
eggs
directory
.
the
eggs
directory
.
...
@@ -235,6 +279,11 @@ If we run Buildout::
...
@@ -235,6 +279,11 @@ If we run Buildout::
</
logfile
>
</
logfile
>
</
eventlog
>
</
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
The
**
details
aren
't important**, other than the fact that the
configuration file reflects part options and the actual buildout
configuration file reflects part options and the actual buildout
location.
location.
...
@@ -320,6 +369,10 @@ Buildout to *not* check for newer versions of Python requirements::
...
@@ -320,6 +369,10 @@ Buildout to *not* check for newer versions of Python requirements::
buildout
-
N
buildout
-
N
..
->
src
>>>
run_buildout
(
src
)
This
relaxes
repeatability
,
but
with
little
risk
if
there
was
a
recent
This
relaxes
repeatability
,
but
with
little
risk
if
there
was
a
recent
run
without
this
option
.
run
without
this
option
.
...
@@ -333,6 +386,22 @@ where you list them, as in::
...
@@ -333,6 +386,22 @@ where you list them, as in::
recipe
=
zc
.
recipe
.
egg
recipe
=
zc
.
recipe
.
egg
eggs
=
ZEO
<
5.0
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.
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::
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::
...
@@ -352,7 +421,15 @@ The more common way to pin version is using a ``versions`` section::
-a 127.0.0.1:8200
-a 127.0.0.1:8200
[versions]
[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
Larger projects may need to pin many versions, so it'
s
common
to
put
versions
in
their
own
file
::
versions
in
their
own
file
::
...
@@ -372,6 +449,10 @@ versions in their own file::
...
@@ -372,6 +449,10 @@ versions in their own file::
-
f
${
buildout
:
directory
}/
data
.
fs
-
f
${
buildout
:
directory
}/
data
.
fs
-
a
127.0.0.1
:
8200
-
a
127.0.0.1
:
8200
..
->
src
>>>
write
(
src
,
'buildout.cfg'
)
Here
,
we
've used the Buildout ``extends`` option to say that
Here
,
we
've used the Buildout ``extends`` option to say that
configurations should be read from the named file (or files) and that
configurations should be read from the named file (or files) and that
configuration in the current file should override configuration in the
configuration in the current file should override configuration in the
...
@@ -379,12 +460,19 @@ extended files. To continue the example, our ``versions.cfg`` file
...
@@ -379,12 +460,19 @@ extended files. To continue the example, our ``versions.cfg`` file
might look like::
might look like::
[versions]
[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
We can use the ``update-versions-file`` option to ask Buildout to
maintain our ``versions.cfg`` file for us::
maintain our ``versions.cfg`` file for us::
[buildout]
[buildout]
extends = versions.cfg
extends = versions.cfg
show-picked-versions = true
show-picked-versions = true
...
@@ -403,6 +491,14 @@ maintain our ``versions.cfg`` file for us::
...
@@ -403,6 +491,14 @@ maintain our ``versions.cfg`` file for us::
-f ${buildout:directory}/data.fs
-f ${buildout:directory}/data.fs
-a 127.0.0.1:8200
-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
With ``update-versions-file``, whenever Buildout gets the newest
version for a requirement (subject to requirement constraints), it
version for a requirement (subject to requirement constraints), it
appends the version to the named file, along with a comment saying
appends the version to the named file, along with a comment saying
...
@@ -440,20 +536,27 @@ Buildout versions and automatic upgrade
...
@@ -440,20 +536,27 @@ Buildout versions and automatic upgrade
In the interest of repeatability, Buildout can upgrade itself or its
In the interest of repeatability, Buildout can upgrade itself or its
dependencies to use the newest versions or downgrade to respect pinned
dependencies to use the newest versions or downgrade to respect pinned
versions. This only happens if you run Buildout from a buildout'
s
own
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
``
bin
``
directory
.
noticed the message::
Not upgrading because not running a local buildout command.
We
can
use
Buildout
's ``bootstrap`` command to install a local
We
can
use
Buildout
's ``bootstrap`` command to install a local
buildout script::
buildout script::
buildout bootstrap
buildout bootstrap
.. -> src
>>> nope('
buildout
' in ls('
bin
'))
>>> run_buildout(src)
>>> yup('
buildout
' in ls('
bin
'))
Then, if the installed script is used::
Then, if the installed script is used::
bin/buildout
bin/buildout
.. -> src
>>> yup(os.path.exists(src.strip()))
Then Buildout will upgrade or downgrade to be consistent with version
Then Buildout will upgrade or downgrade to be consistent with version
requirements. See the :doc:`bootstrapping topic
requirements. See the :doc:`bootstrapping topic
<topics/bootstrapping>` to learn more about bootstrapping.
<topics/bootstrapping>` to learn more about bootstrapping.
...
@@ -469,6 +572,8 @@ facilitates this with the ``develop`` option::
...
@@ -469,6 +572,8 @@ facilitates this with the ``develop`` option::
develop = .
develop = .
...
...
.. -> develop_snippet
The ``develop`` option takes one more more paths to project `setup.py
The ``develop`` option takes one more more paths to project `setup.py
<https://docs.python.org/3.6/distutils/setupscript.html>`_ files or,
<https://docs.python.org/3.6/distutils/setupscript.html>`_ files or,
more commonly, directories containing them. Buildout then creates
more commonly, directories containing them. Buildout then creates
...
@@ -496,7 +601,11 @@ Fortunately, an application setup script can be minimal. Here's an
...
@@ -496,7 +601,11 @@ Fortunately, an application setup script can be minimal. Here's an
example::
example::
from setuptools import setup
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
We suggest copying and modifying the example above, using it as
boilerplate. As is probably clear, the setup arguments used:
boilerplate. As is probably clear, the setup arguments used:
...
@@ -523,6 +632,15 @@ something like this::
...
@@ -523,6 +632,15 @@ something like this::
eggs
=
main
eggs
=
main
interpreter
=
py
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*
There
's a new option, ``interpreter``, which names an *interpreter*
script to be generated. An interpreter script [#interpreter-script]_
script to be generated. An interpreter script [#interpreter-script]_
mimics a Python interpreter with its path set to include the
mimics a Python interpreter with its path set to include the
...
@@ -531,10 +649,18 @@ dependencies. We can run the interpreter::
...
@@ -531,10 +649,18 @@ dependencies. We can run the interpreter::
bin/py
bin/py
.. -> path
>>> yup(os.getcwd() in read(path.strip()))
To get an interactive Python prompt, or you can run a script with it::
To get an interactive Python prompt, or you can run a script with it::
bin/py somescript.py
bin/py somescript.py
.. -> path
>>> yup(os.path.exists(path.split()[0]))
If you need to work on multiple interdependent projects at the same
If you need to work on multiple interdependent projects at the same
time, you can name multiple directories in the ``develop`` option,
time, you can name multiple directories in the ``develop`` option,
typically pointing to multiple check outs. A popular Buildout
typically pointing to multiple check outs. A popular Buildout
...
...
setup.py
View file @
58125125
...
@@ -92,7 +92,8 @@ setup(
...
@@ -92,7 +92,8 @@ setup(
],
],
include_package_data
=
True
,
include_package_data
=
True
,
entry_points
=
entry_points
,
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
,
zip_safe
=
False
,
classifiers
=
[
classifiers
=
[
'Intended Audience :: Developers'
,
'Intended Audience :: Developers'
,
...
...
src/zc/buildout/tests.py
View file @
58125125
...
@@ -13,7 +13,7 @@
...
@@ -13,7 +13,7 @@
#
#
##############################################################################
##############################################################################
from
zc.buildout.buildout
import
print_
from
zc.buildout.buildout
import
print_
from
zope.testing
import
renormalizing
from
zope.testing
import
renormalizing
,
setupstack
import
doctest
import
doctest
import
manuel.capture
import
manuel.capture
...
@@ -3375,10 +3375,14 @@ def updateSetup(test):
...
@@ -3375,10 +3375,14 @@ def updateSetup(test):
makeNewRelease
(
dist
.
key
,
ws
,
new_releases
)
makeNewRelease
(
dist
.
key
,
ws
,
new_releases
)
os
.
mkdir
(
os
.
path
.
join
(
new_releases
,
dist
.
key
))
os
.
mkdir
(
os
.
path
.
join
(
new_releases
,
dist
.
key
))
bootstrap_py
=
os
.
path
.
join
(
def
ancestor
(
path
,
level
):
os
.
path
.
dirname
(
os
.
path
.
dirname
(
os
.
path
.
dirname
(
while
level
>
0
:
os
.
path
.
dirname
(
__file__
)))),
path
=
os
.
path
.
dirname
(
path
)
'bootstrap'
,
'bootstrap.py'
)
level
-=
1
return
path
bootstrap_py
=
os
.
path
.
join
(
ancestor
(
__file__
,
4
),
'bootstrap'
,
'bootstrap.py'
)
def
bootstrapSetup
(
test
):
def
bootstrapSetup
(
test
):
buildout_txt_setup
(
test
)
buildout_txt_setup
(
test
)
...
@@ -3402,6 +3406,21 @@ normalize_S = (
...
@@ -3402,6 +3406,21 @@ normalize_S = (
'#!/usr/local/bin/python2.7'
,
'#!/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
():
def
test_suite
():
test_suite
=
[
test_suite
=
[
manuel
.
testing
.
TestSuite
(
manuel
.
testing
.
TestSuite
(
...
@@ -3663,6 +3682,54 @@ def test_suite():
...
@@ -3663,6 +3682,54 @@ def test_suite():
'
testing_bugfix
.
txt
'),
'
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
# adding bootstrap.txt doctest to the suite
# only if bootstrap.py is present
# only if bootstrap.py is present
if os.path.exists(bootstrap_py):
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