Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.rebootstrap
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
nexedi
slapos.rebootstrap
Commits
1154c006
Commit
1154c006
authored
May 22, 2024
by
Xavier Thompson
Browse files
Options
Browse Files
Download
Plain Diff
Adapt rebootstrap to setuptools >= 52.0.0 without easy_install
See merge request
!5
parents
b86affad
1b51c7c2
Pipeline
#34735
passed with stage
in 0 seconds
Changes
7
Pipelines
1
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
91 additions
and
140 deletions
+91
-140
CHANGELOG.rst
CHANGELOG.rst
+7
-0
setup.py
setup.py
+1
-1
slapos/rebootstrap/__init__.py
slapos/rebootstrap/__init__.py
+43
-53
slapos/rebootstrap/bootstrap.py
slapos/rebootstrap/bootstrap.py
+0
-77
slapos/rebootstrap/different_version.txt
slapos/rebootstrap/different_version.txt
+13
-3
slapos/rebootstrap/same_version.txt
slapos/rebootstrap/same_version.txt
+17
-1
slapos/rebootstrap/tests.py
slapos/rebootstrap/tests.py
+10
-5
No files found.
CHANGELOG.rst
View file @
1154c006
Changes
=======
4.7 (2024-05-22)
----------------
- Stop using deprecated setuptools.easy_install
- Check zc.buildout version on import
- Unify rebootstrap mechanisms
4.6 (2024-03-26)
----------------
...
...
setup.py
View file @
1154c006
from
setuptools
import
setup
,
find_packages
version
=
'4.
6
'
version
=
'4.
7
'
name
=
"slapos.rebootstrap"
long_description
=
open
(
"README.rst"
).
read
()
+
'
\
n
\
n
'
...
...
slapos/rebootstrap/__init__.py
View file @
1154c006
...
...
@@ -12,8 +12,31 @@
#
##############################################################################
import
errno
,
logging
,
os
,
shutil
,
subprocess
,
sys
,
tempfile
from
zc.buildout
import
easy_install
,
UserError
import
errno
,
logging
,
os
,
shutil
,
subprocess
,
sys
import
pkg_resources
from
zc.buildout
import
UserError
buildout_dist
=
pkg_resources
.
get_distribution
(
'zc.buildout'
)
if
'slapos'
not
in
str
(
buildout_dist
.
version
):
raise
UserError
(
"Incompatible version %s
\
n
"
"Consider installing e.g. zc.buildout==3.0.1+slapos001"
%
buildout_dist
)
def
get_paths
():
# zc.buildout and dependencies
dists
=
pkg_resources
.
require
(
'zc.buildout'
)
# propagate slapos.libnetworkcache availability
try
:
import
slapos.libnetworkcache
dists
.
append
(
pkg_resources
.
get_distribution
(
'slapos.libnetworkcache'
))
except
ImportError
:
pass
# keep same order as in sys.path
paths
=
{
d
.
location
for
d
in
dists
}
return
[
p
for
p
in
sys
.
path
if
p
in
paths
]
class
extension
(
object
):
...
...
@@ -69,55 +92,22 @@ Buildout will be restarted automatically to have this change applied.
if
e
.
errno
!=
errno
.
ENOENT
:
raise
x
=
None
if
x
!=
'#!'
+
self
.
wanted_python
:
from
.bootstrap
import
get_distributions
,
setup_script
if
subprocess
.
call
((
self
.
wanted_python
,
'-c'
,
'import sys; sys.exit(sys.version_info[:2] == %r)'
%
(
sys
.
version_info
[:
2
],))):
setup_script
(
new_bin
,
self
.
wanted_python
)
else
:
# With a different version of Python,
# we must reinstall required eggs from source.
from
pkg_resources
import
resource_string
with
Cache
(
buildout
[
'buildout'
])
as
cache
:
subprocess
.
check_call
([
self
.
wanted_python
,
'-c'
,
resource_string
(
__name__
,
'bootstrap.py'
),
new_bin
,
cache
.
_dest
,
cache
.
tmp
,
]
+
list
(
map
(
cache
,
get_distributions
())))
if
x
==
'#!'
+
self
.
wanted_python
:
shutil
.
copy
(
new_bin
,
installed
)
else
:
old
=
installed
+
'-old'
shutil
.
move
(
installed
,
old
)
try
:
paths
=
get_paths
()
args
=
[
arg
for
arg
in
sys
.
argv
if
arg
.
startswith
(
'buildout:'
)]
subprocess
.
check_call
(
[
self
.
wanted_python
,
'-c'
,
"import sys ; sys.path[0:0]=%r ; "
"import zc.buildout.buildout ; "
"sys.argv[1:1]=%r ; "
"zc.buildout.buildout.main()"
%
(
paths
,
args
+
[
'bootstrap'
])])
except
subprocess
.
CalledProcessError
:
shutil
.
move
(
old
,
installed
)
raise
shutil
.
copy
(
installed
,
new_bin
)
os
.
execve
(
self
.
wanted_python
,
[
self
.
wanted_python
]
+
sys
.
argv
,
self
.
environ
)
class
Cache
(
easy_install
.
Installer
):
def
__init__
(
self
,
buildout
):
easy_install
.
Installer
.
__init__
(
self
,
buildout
[
'eggs-directory'
],
buildout
.
get
(
'find-links'
,
''
).
split
())
def
__enter__
(
self
):
self
.
tmp
=
self
.
_download_cache
or
tempfile
.
mkdtemp
(
'get_dist'
)
return
self
def
__exit__
(
self
,
t
,
v
,
tb
):
if
self
.
tmp
is
not
self
.
_download_cache
:
shutil
.
rmtree
(
self
.
tmp
)
del
self
.
tmp
def
__call__
(
self
,
dist
):
req
=
dist
.
as_requirement
()
cache
=
self
.
_download_cache
if
cache
:
from
pkg_resources
import
SOURCE_DIST
for
avail
in
self
.
_index
[
dist
.
project_name
]:
if
(
avail
.
version
==
dist
.
version
and
avail
.
precedence
==
SOURCE_DIST
and
cache
==
os
.
path
.
dirname
(
avail
.
location
)):
return
str
(
req
)
avail
=
self
.
_obtain
(
req
,
True
)
if
avail
is
None
:
raise
UserError
(
"Couldn't find a distribution for %r"
%
str
(
req
))
if
self
.
_fetch
(
avail
,
self
.
tmp
,
cache
)
is
None
:
raise
UserError
(
"Couldn't download distribution %s."
%
avail
)
return
str
(
req
)
slapos/rebootstrap/bootstrap.py
deleted
100644 → 0
View file @
b86affad
import
errno
,
os
,
sys
class
FakeSysExecutable
(
object
):
def
__init__
(
self
,
python
):
self
.
executable
=
python
def
__getattr__
(
self
,
attr
):
return
getattr
(
sys
,
attr
)
def
get_distributions
():
from
pkg_resources
import
get_distribution
distributions
=
[
'setuptools'
,
'zc.buildout'
,
'wheel'
,
'pip'
]
try
:
import
slapos.libnetworkcache
except
ImportError
:
pass
else
:
distributions
.
append
(
'slapos.libnetworkcache'
)
return
map
(
get_distribution
,
distributions
)
def
setup_script
(
path
,
python
=
sys
.
executable
):
from
zc.buildout
import
easy_install
executable_path
=
os
.
path
.
realpath
(
path
)
assert
os
.
path
.
isabs
(
executable_path
)
try
:
if
sys
.
executable
!=
python
:
easy_install
.
sys
=
FakeSysExecutable
(
python
)
easy_install
.
scripts
(
((
os
.
path
.
basename
(
executable_path
),
'zc.buildout.buildout'
,
'main'
),),
get_distributions
(),
python
,
os
.
path
.
dirname
(
executable_path
)
)
finally
:
easy_install
.
sys
=
sys
def
main
():
import
shutil
,
subprocess
,
tarfile
,
tempfile
,
zipfile
eggs_dir
=
sys
.
argv
[
2
]
cache
=
sys
.
argv
[
3
]
base
=
os
.
path
.
join
(
cache
,
sys
.
argv
[
4
].
replace
(
'=='
,
'-'
))
# Install setuptools.
tmp
=
tempfile
.
mkdtemp
()
try
:
try
:
with
zipfile
.
ZipFile
(
base
+
'.zip'
)
as
zip_file
:
zip_file
.
extractall
(
tmp
)
except
IOError
as
e
:
if
e
.
errno
!=
errno
.
ENOENT
:
raise
with
tarfile
.
open
(
base
+
'.tar.gz'
)
as
tar_file
:
tar_file
.
extractall
(
tmp
)
src
,
=
os
.
listdir
(
tmp
)
subprocess
.
check_call
((
sys
.
executable
,
'setup.py'
,
'-q'
,
'bdist_egg'
,
'--dist-dir'
,
tmp
),
cwd
=
os
.
path
.
join
(
tmp
,
src
))
egg
=
os
.
listdir
(
tmp
)
egg
.
remove
(
src
)
egg
,
=
egg
dst
=
os
.
path
.
join
(
eggs_dir
,
egg
)
os
.
path
.
exists
(
dst
)
or
shutil
.
move
(
os
.
path
.
join
(
tmp
,
egg
),
dst
)
finally
:
shutil
.
rmtree
(
tmp
)
sys
.
path
.
insert
(
0
,
dst
)
# Install other requirements given on command line.
from
pkg_resources
import
working_set
,
require
from
setuptools.command
import
easy_install
reqs
=
sys
.
argv
[
5
:]
easy_install
.
main
([
'-mZqNxd'
,
eggs_dir
,
'-f'
,
cache
]
+
reqs
)
working_set
.
add_entry
(
eggs_dir
)
for
req
in
reqs
:
require
(
req
)
# Generate bin/buildout-rebootstrap script.
setup_script
(
sys
.
argv
[
1
])
if
__name__
==
'__main__'
:
sys
.
exit
(
main
())
slapos/rebootstrap/different_version.txt
View file @
1154c006
...
...
@@ -62,6 +62,10 @@ Develop: '/sample-buildout/recipes'
... recipe = recipes:pyshow
... """ % dict(syspython=sys.executable))
>>> cat(buildout) # doctest: +ELLIPSIS
#!/system_python
...
>>> print(system(buildout, env={'PYTHONWARNINGS':'ignore'})) # doctest: +ELLIPSIS
slapos.rebootstrap: Make sure that the section 'installpython' won't be reinstalled after rebootstrap.
Develop: '/sample-buildout/recipes'
...
...
@@ -75,7 +79,13 @@ is available, and buildout is using another python:
Buildout will be restarted automatically to have this change applied.
************ REBOOTSTRAP: IMPORTANT NOTICE ************
<BLANKLINE>
While:
Installing.
Error: Couldn't find a distribution for 'setuptools==...'
Generated script '/sample-buildout/bin/buildout'.
Develop: '/sample-buildout/recipes'
Updating installpython.
Installing realrun.
Running with: /sample_buildout/parts/installpython/bin/python
<BLANKLINE>
>>> cat(buildout) # doctest: +ELLIPSIS
/sample-buildout/parts/installpython/bin/python
...
slapos/rebootstrap/same_version.txt
View file @
1154c006
...
...
@@ -22,6 +22,10 @@ Develop: '/sample-buildout/recipes'
... recipe = recipes:pyshow
... """ % dict(syspython=sys.executable))
>>> cat(buildout) # doctest: +ELLIPSIS
#!/system_python
...
>>> print(system(buildout, env={'PYTHONWARNINGS':'ignore'}))
slapos.rebootstrap: Make sure that the section 'installpython' won't be reinstalled after rebootstrap.
Develop: '/sample-buildout/recipes'
...
...
@@ -35,13 +39,17 @@ is available, and buildout is using another python:
Buildout will be restarted automatically to have this change applied.
************ REBOOTSTRAP: IMPORTANT NOTICE ************
<BLANKLINE>
Generated script '/sample-buildout/bin/buildout
-rebootstrap
'.
Generated script '/sample-buildout/bin/buildout'.
Develop: '/sample-buildout/recipes'
Updating installpython.
Installing realrun.
Running with: /sample_buildout/parts/installpython/bin/python
<BLANKLINE>
>>> cat(buildout) # doctest: +ELLIPSIS
/sample-buildout/parts/installpython/bin/python
...
>>> print(system(buildout, env={'PYTHONWARNINGS':'ignore'}))
Develop: '/sample-buildout/recipes'
Updating installpython.
...
...
@@ -49,6 +57,10 @@ Updating realrun.
Running with: /sample_buildout/parts/installpython/bin/python
<BLANKLINE>
>>> cat(buildout) # doctest: +ELLIPSIS
/sample-buildout/parts/installpython/bin/python
...
>>> cp(buildout + '-orig', buildout)
>>> print(system(buildout, env={'PYTHONWARNINGS':'ignore'}))
slapos.rebootstrap: Make sure that the section 'installpython' won't be reinstalled after rebootstrap.
...
...
@@ -68,3 +80,7 @@ Updating installpython.
Updating realrun.
Running with: /sample_buildout/parts/installpython/bin/python
<BLANKLINE>
>>> cat(buildout) # doctest: +ELLIPSIS
/sample-buildout/parts/installpython/bin/python
...
slapos/rebootstrap/tests.py
View file @
1154c006
...
...
@@ -50,12 +50,16 @@ class Pyinstall:
def __init__(self, buildout, name, options):
self.options = options
options['executable'] = os.path.join(buildout['buildout'][
'parts-directory'], name
, 'bin', 'python')
self.part_dir = os.path.join(buildout['buildout']['parts-directory'], name)
options['executable'] = os.path.join(self.part_dir
, 'bin', 'python')
def install(self):
python = self.options['executable']
if not os.path.exists(python):
try:
from venv import create
create(self.part_dir, clear=True)
except ImportError:
d = os.path.dirname(python)
os.path.exists(d) or os.makedirs(d)
shutil.copy(sys.executable, python)
...
...
@@ -124,6 +128,7 @@ def test_suite():
''
),
zc
.
buildout
.
testing
.
normalize_path
,
zc
.
buildout
.
testing
.
not_found
,
zc
.
buildout
.
testing
.
root_logger_messages
,
]),
)
test_list
=
[]
...
...
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