Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
moodle_rebase10.1.2
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
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Dmitry Blinov
moodle_rebase10.1.2
Commits
d9d081b2
Commit
d9d081b2
authored
Jan 11, 2012
by
Antoine Catton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Transform erp5testnode recipe into generic recipe.
parent
faa63131
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
62 additions
and
68 deletions
+62
-68
slapos/recipe/erp5testnode/__init__.py
slapos/recipe/erp5testnode/__init__.py
+62
-68
No files found.
slapos/recipe/erp5testnode/__init__.py
View file @
d9d081b2
...
@@ -24,86 +24,80 @@
...
@@ -24,86 +24,80 @@
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#
#
##############################################################################
##############################################################################
from
slapos.recipe.librecipe
import
BaseSlapRecipe
import
ConfigParser
import
json
import
os
import
os
import
pkg_resources
import
StringIO
import
zc.buildout
import
zc.recipe.egg
import
sys
class
Recipe
(
BaseSlapRecipe
):
from
slapos.recipe.librecipe
import
GenericBaseRecipe
def
__init__
(
self
,
buildout
,
name
,
options
):
self
.
egg
=
zc
.
recipe
.
egg
.
Egg
(
buildout
,
options
[
'recipe'
],
options
)
BaseSlapRecipe
.
__init__
(
self
,
buildout
,
name
,
options
)
def
_install
(
self
):
class
Recipe
(
GenericBaseRecipe
):
self
.
requirements
,
self
.
ws
=
self
.
egg
.
working_set
()
def
install
(
self
):
path_list
=
[]
path_list
=
[]
CONFIG
=
dict
()
options
=
self
.
options
.
copy
()
CONFIG
[
'slapos_directory'
]
=
self
.
createDataDirectory
(
'slapos'
)
del
options
[
'recipe'
]
CONFIG
[
'working_directory'
]
=
self
.
createDataDirectory
(
'testnode'
)
CONFIG
=
{
k
.
replace
(
'-'
,
'_'
):
v
for
k
,
v
in
options
.
iteritems
()}
CONFIG
[
'test_suite_directory'
]
=
self
.
createDataDirectory
(
'test_suite'
)
CONFIG
[
'proxy_host'
]
=
self
.
getLocalIPv4Address
()
CONFIG
[
'proxy_port'
]
=
'5000'
CONFIG
[
'log_directory'
]
=
self
.
createDataDirectory
(
'testnodelog'
)
CONFIG
[
'run_directory'
]
=
self
.
createDataDirectory
(
'testnoderun'
)
CONFIG
[
'test_suite_title'
]
=
self
.
parameter_dict
.
get
(
'test_suite_title'
)
CONFIG
[
'test_node_title'
]
=
self
.
parameter_dict
.
get
(
'test_node_title'
)
CONFIG
[
'test_suite'
]
=
self
.
parameter_dict
.
get
(
'test_suite'
)
CONFIG
[
'node_quantity'
]
=
self
.
parameter_dict
.
get
(
'node_quantity'
,
'1'
)
CONFIG
[
'project_title'
]
=
self
.
parameter_dict
.
get
(
'project_title'
)
CONFIG
[
'ipv4_address'
]
=
self
.
getLocalIPv4Address
()
CONFIG
[
'ipv6_address'
]
=
self
.
getGlobalIPv6Address
()
CONFIG
[
'test_suite_master_url'
]
=
self
.
parameter_dict
.
get
(
'test_suite_master_url'
,
None
)
CONFIG
[
'git_binary'
]
=
self
.
options
[
'git_binary'
]
CONFIG
[
'slapgrid_partition_binary'
]
=
self
.
options
[
'slapgrid_partition_binary'
]
CONFIG
[
'slapgrid_software_binary'
]
=
self
.
options
[
'slapgrid_software_binary'
]
CONFIG
[
'slapproxy_binary'
]
=
self
.
options
[
'slapproxy_binary'
]
CONFIG
[
'zip_binary'
]
=
self
.
options
[
'zip_binary'
]
CONFIG
[
'PATH'
]
=
os
.
environ
[
'PATH'
]
CONFIG
[
'PATH'
]
=
os
.
environ
[
'PATH'
]
additional_bt5_repository_id
=
\
self
.
parameter_dict
.
get
(
'additional_bt5_repository_id'
)
CONFIG
[
'bt5_path'
]
=
None
if
CONFIG
[
'bt5_path'
]:
if
additional_bt5_repository_id
is
not
None
:
additional_bt5_repository_id_list
=
CONFIG
[
'bt5_path'
].
split
(
","
)
CONFIG
[
'bt5_path'
]
=
""
CONFIG
[
'bt5_path'
]
=
''
additional_bt5_repository_id_list
=
additional_bt5_repository_id
.
split
(
","
)
for
bt5_repository_id
in
additional_bt5_repository_id_list
:
for
id
in
additional_bt5_repository_id_list
:
id_path
=
os
.
path
.
join
(
CONFIG
[
'slapos_directory'
],
bt5_repository_id
)
id_path
=
os
.
path
.
join
(
CONFIG
[
'slapos_directory'
],
id
)
bt_path
=
os
.
path
.
join
(
id_path
,
"bt5"
)
bt_path
=
os
.
path
.
join
(
id_path
,
"bt5"
)
CONFIG
[
'bt5_path'
]
+=
"%s,%s,"
%
(
id_path
,
bt_path
)
CONFIG
[
'bt5_path'
]
+=
"%s,%s,"
%
(
id_path
,
bt_path
)
CONFIG
[
'instance_dict'
]
=
''
if
'instance_dict'
in
self
.
parameter_dict
:
CONFIG
[
'instance_dict'
]
=
'[instance_dict]
\
n
'
for
k
,
v
in
eval
(
self
.
parameter_dict
[
'instance_dict'
]).
iteritems
():
CONFIG
[
'instance_dict'
]
+=
'%s = %s
\
n
'
%
(
k
,
v
)
CONFIG
[
'repository_list'
]
=
''
if
self
.
options
[
'instance-dict'
]:
config_instance_dict
=
ConfigParser
.
ConfigParser
()
config_instance_dict
.
add_section
(
'instance_dict'
)
instance_dict
=
json
.
loads
(
self
.
options
[
'instance-dict'
])
for
k
,
v
in
instance_dict
.
iteritems
():
config_instance_dict
.
set
(
'instance_dict'
,
k
,
v
)
value
=
StringIO
.
StringIO
()
config_instance_dict
.
write
(
value
)
CONFIG
[
'instance_dict'
]
=
value
.
getvalue
()
vcs_repository_list
=
json
.
loads
(
self
.
options
[
'repository-list'
])
config_repository_list
=
ConfigParser
.
ConfigParser
()
i
=
0
i
=
0
for
repository
in
eval
(
self
.
parameter_dict
[
'vcs_repository_list'
]):
for
repository
in
vcs_repository_list
:
CONFIG
[
'repository_list'
]
+=
'[vcs_repository_%s]
\
n
'
%
i
section_name
=
'vcs_repository_%d'
%
i
CONFIG
[
'repository_list'
]
+=
'url = %s
\
n
'
%
repository
[
'url'
]
config_repository_list
.
add_section
(
section_name
)
config_repository_list
.
set
(
section_name
,
'url'
,
repository
[
'url'
])
if
'branch'
in
repository
:
if
'branch'
in
repository
:
CONFIG
[
'repository_list'
]
+=
'branch = %s
\
n
'
%
repository
[
'branch'
]
config_repository_list
.
set
(
section_name
,
'branch'
,
repository
[
'branch'
])
if
'profile_path'
in
repository
:
if
'profile_path'
in
repository
:
CONFIG
[
'repository_list'
]
+=
'profile_path = %s
\
n
'
%
repository
[
config_repository_list
.
set
(
section_name
,
'profile_path'
,
'profile_path'
]
repository
[
'profile_path'
])
if
'buildout_section_id'
in
repository
:
if
'buildout_section_id'
in
repository
:
CONFIG
[
'repository_list'
]
+=
'buildout_section_id = %s
\
n
'
%
repository
[
config_repository_list
.
set
(
section_name
,
'buildout_section_id'
,
'buildout_section_id'
]
repository
[
'buildout_section_id'
])
CONFIG
[
'repository_list'
]
+=
'
\
n
'
i
+=
1
i
+=
1
testnode_config
=
self
.
createConfigurationFile
(
'erp5testnode.cfg'
,
value
=
StringIO
.
StringIO
()
self
.
substituteTemplate
(
pkg_resources
.
resource_filename
(
__name__
,
config_repository_list
.
write
(
value
)
'template/erp5testnode.cfg.in'
),
CONFIG
))
CONFIG
[
'repository_list'
]
=
value
.
getvalue
()
testnode_log
=
os
.
path
.
join
(
self
.
log_directory
,
'erp5testnode.log'
)
wrapper
=
zc
.
buildout
.
easy_install
.
scripts
([(
'erp5testnode'
,
configuration_file
=
self
.
createFile
(
'slapos.recipe.librecipe.execute'
,
'executee'
)],
self
.
ws
,
sys
.
executable
,
self
.
options
[
'configuration-file'
],
self
.
wrapper_directory
,
arguments
=
[[
self
.
options
[
'testnode'
],
'-l'
,
self
.
substituteTemplate
(
testnode_log
,
testnode_config
],
{
'GIT_SSL_NO_VERIFY'
:
'1'
}])[
0
]
self
.
getTemplateFilename
(
'erp5testnode.cfg.in'
),
path_list
.
append
(
testnode_config
)
CONFIG
path_list
.
append
(
wrapper
)
),
)
path_list
.
append
(
configuration_file
)
path_list
.
append
(
self
.
createPythonScript
(
self
.
options
[
'wrapper'
],
'slapos.recipe.librecipe.execute.executee'
,
[
# Executable
[
self
.
options
[
'testnode'
],
'-l'
,
self
.
options
[
'log-file'
],
configuration_file
],
# Environment
{
'GIT_SSL_NO_VERIFY'
:
'1'
,
}
],
)
)
return
path_list
return
path_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