Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
slapos
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
104
Merge Requests
104
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
nexedi
slapos
Commits
77e1da6b
Commit
77e1da6b
authored
Jan 02, 2025
by
Vincent Pelletier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Revert a few commits pushed by mistake.
parent
da59bc81
Pipeline
#38803
failed with stage
in 0 seconds
Changes
7
Pipelines
1
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
96 additions
and
174 deletions
+96
-174
software/rapid-cdn/test/test.py
software/rapid-cdn/test/test.py
+2
-59
stack/erp5/buildout.hash.cfg
stack/erp5/buildout.hash.cfg
+5
-5
stack/erp5/haproxy.cfg.in
stack/erp5/haproxy.cfg.in
+1
-1
stack/erp5/instance-mariadb-resiliency-after-import-script.sh.in
...rp5/instance-mariadb-resiliency-after-import-script.sh.in
+27
-43
stack/erp5/instance-mariadb-start-clone-from-backup.sh.in
stack/erp5/instance-mariadb-start-clone-from-backup.sh.in
+55
-58
stack/erp5/instance-mariadb.cfg.in
stack/erp5/instance-mariadb.cfg.in
+5
-7
stack/erp5/instance-zope.cfg.in
stack/erp5/instance-zope.cfg.in
+1
-1
No files found.
software/rapid-cdn/test/test.py
View file @
77e1da6b
...
@@ -90,27 +90,6 @@ SOURCE_IPV6 = '::1'
...
@@ -90,27 +90,6 @@ SOURCE_IPV6 = '::1'
# IP on which test run, in order to mimic HTTP[s] access
# IP on which test run, in order to mimic HTTP[s] access
TEST_IP
=
os
.
environ
[
'SLAPOS_TEST_IPV4'
]
TEST_IP
=
os
.
environ
[
'SLAPOS_TEST_IPV4'
]
# "--resolve" inspired from https://stackoverflow.com/a/44378047/9256748
DNS_CACHE
=
{}
MONTH_DICT
=
{
'Jan'
:
1
,
'Feb'
:
2
,
'Mar'
:
3
,
'Apr'
:
4
,
'May'
:
5
,
'Jun'
:
6
,
'Jul'
:
7
,
'Aug'
:
8
,
'Sep'
:
9
,
'Oct'
:
10
,
'Nov'
:
11
,
'Dec'
:
12
,
}
match_nginx_datetime
=
re
.
compile
(
'(?P<dow>...), (?P<day>..) (?P<monthname>...) (?P<year>....) '
'(?P<hour>..):(?P<minute>..):(?P<second>..)'
,
).
match
def
unicode_escape
(
s
):
def
unicode_escape
(
s
):
return
s
.
encode
(
'unicode_escape'
).
decode
()
return
s
.
encode
(
'unicode_escape'
).
decode
()
...
@@ -1072,45 +1051,9 @@ class HttpFrontendTestCase(SlapOSInstanceTestCase):
...
@@ -1072,45 +1051,9 @@ class HttpFrontendTestCase(SlapOSInstanceTestCase):
'application/json'
,
'application/json'
,
result
.
headers
[
'Content-Type'
]
result
.
headers
[
'Content-Type'
]
)
)
result_json
=
result
.
json
()
# expected content for each file entry:
# - 'type' with files having the value 'file'
# - 'name' with the file's basename as value
# - 'mtime' with the modification time (though this specific part
# probably cannot be reliably tested) in some specific format (which
# happens to be the one nginx produces)
# - 'size' with the file's size (again, not much to actually test for
# exctitude I guess)
self
.
assertEqual
(
sorted
([
q
[
'name'
]
for
q
in
result_json
]),
[
'access.log'
,
'backend.log'
,
'frontend.log'
])
self
.
assertIn
(
'file'
,
{
q
[
'type'
]
for
q
in
result_json
},
)
# The following loop must not raise to pass the test, but nothing specific
# is done with extracted values.
for
entry
in
result_json
:
self
.
assertIn
(
'size'
,
entry
)
parsed_remote_mtime
=
match_nginx_datetime
(
entry
[
'mtime'
],
).
groupdict
()
datetime
.
datetime
(
int
(
parsed_remote_mtime
[
'year'
],
10
),
MONTH_DICT
[
parsed_remote_mtime
[
'monthname'
]],
int
(
parsed_remote_mtime
[
'day'
],
10
),
int
(
parsed_remote_mtime
[
'hour'
],
10
),
int
(
parsed_remote_mtime
[
'minute'
],
10
),
int
(
parsed_remote_mtime
[
'second'
],
10
),
)
self
.
assertEqual
(
http
.
client
.
OK
,
requests
.
get
(
url
+
'access.log'
,
verify
=
False
).
status_code
)
self
.
assertEqual
(
self
.
assertEqual
(
http
.
client
.
OK
,
sorted
([
q
[
'name'
]
for
q
in
result
.
json
()]),
requests
.
get
(
url
+
'error.log'
,
verify
=
False
).
status_code
[
'access.log'
,
'backend.log'
,
'frontend.log'
])
)
# assert only for few tests, as logs are available for sure only
# assert only for few tests, as logs are available for sure only
# for few of them
# for few of them
for
test_name
in
[
for
test_name
in
[
...
...
stack/erp5/buildout.hash.cfg
View file @
77e1da6b
...
@@ -14,7 +14,7 @@
...
@@ -14,7 +14,7 @@
# not need these here).
# not need these here).
[mariadb-resiliency-after-import-script]
[mariadb-resiliency-after-import-script]
filename = instance-mariadb-resiliency-after-import-script.sh.in
filename = instance-mariadb-resiliency-after-import-script.sh.in
md5sum =
f97ad39b3c9f539e80ac86cf0c0e145b
md5sum =
85ce1e2f3d251aa435fef8118dca8a63
[mariadb-slow-query-report-script]
[mariadb-slow-query-report-script]
filename = mysql-querydigest.sh.in
filename = mysql-querydigest.sh.in
...
@@ -22,11 +22,11 @@ md5sum = 6457ab192d709aa2c9014e9a3e91ca20
...
@@ -22,11 +22,11 @@ md5sum = 6457ab192d709aa2c9014e9a3e91ca20
[mariadb-start-clone-from-backup]
[mariadb-start-clone-from-backup]
filename = instance-mariadb-start-clone-from-backup.sh.in
filename = instance-mariadb-start-clone-from-backup.sh.in
md5sum =
710b812d41c46d5a44b8b487a4f54f8f
md5sum =
d10b8e35b02b5391cf46bf0c7dbb1196
[template-mariadb]
[template-mariadb]
filename = instance-mariadb.cfg.in
filename = instance-mariadb.cfg.in
md5sum =
43acff9f4df025318a4cab0dd2bd4e32
md5sum =
93b2277185e4949a3d17be79d3710d2d
[template-kumofs]
[template-kumofs]
filename = instance-kumofs.cfg.in
filename = instance-kumofs.cfg.in
...
@@ -90,7 +90,7 @@ md5sum = 0ac4b74436f554cd677f19275d18d880
...
@@ -90,7 +90,7 @@ md5sum = 0ac4b74436f554cd677f19275d18d880
[template-zope]
[template-zope]
filename = instance-zope.cfg.in
filename = instance-zope.cfg.in
md5sum =
e7776de36718bd7e27a4defe7d2e5b29
md5sum =
9c580be982d8c63ec06fc273ef3cb971
[template-balancer]
[template-balancer]
filename = instance-balancer.cfg.in
filename = instance-balancer.cfg.in
...
@@ -98,7 +98,7 @@ md5sum = 409a7505548576ebf0e4d5cc218e0753
...
@@ -98,7 +98,7 @@ md5sum = 409a7505548576ebf0e4d5cc218e0753
[template-haproxy-cfg]
[template-haproxy-cfg]
filename = haproxy.cfg.in
filename = haproxy.cfg.in
md5sum =
bdb624dcc3571e4280d2cb2cc7cd7a1
5
md5sum =
2cd76971b64b0bf7771978ad07bfc2e
5
[template-rsyslogd-cfg]
[template-rsyslogd-cfg]
filename = rsyslogd.cfg.in
filename = rsyslogd.cfg.in
...
...
stack/erp5/haproxy.cfg.in
View file @
77e1da6b
...
@@ -261,7 +261,7 @@ frontend frontend_{{ group_name }}
...
@@ -261,7 +261,7 @@ frontend frontend_{{ group_name }}
{% for name, url in sorted(backend_dict.items()) %}
{% for name, url in sorted(backend_dict.items()) %}
backend backend_{{ group_name }}_{{ name }}
backend backend_{{ group_name }}_{{ name }}
http-request replace-path ^/{{ name }}(.*) /VirtualHostBase/https/
%[req.hdr(Host)]
/VirtualHostRoot/_vh_{{ name }}\1
http-request replace-path ^/{{ name }}(.*) /VirtualHostBase/https/
{{ ip }}:{{ port }}
/VirtualHostRoot/_vh_{{ name }}\1
timeout server 8h
timeout server 8h
server {{ name }} {{ urllib_parse.urlparse(url).netloc }}
server {{ name }} {{ urllib_parse.urlparse(url).netloc }}
{%- endfor %}
{%- endfor %}
...
...
stack/erp5/instance-mariadb-resiliency-after-import-script.sh.in
View file @
77e1da6b
#!{{ dash }}
#!{{ dash }}
set -eu
if [ $# -ne 1 ]; then
# DO NOT RUN THIS SCRIPT ON PRODUCTION INSTANCE
echo "Restaure a mariadb instance from available backup data."
# OR MYSQL DATA WILL BE ERASED.
echo " $0 <BACKUP FILE>"
exit 1
# This script will import the dump of the mysql database to the real
fi
# database. It is launched by the clone (importer) instance of webrunner
# in the end of the import script.
# Depending on the output, it will create a file containing
# the status of the restoration (success or failure)
set -e
dump=$1
mysql_executable='{{ mysql_executable }}'
mysql_executable='{{ mysql_executable }}'
mariadb_data_directory='{{ data_directory }}'
mariadb_data_directory='{{ mariadb_data_directory }}'
mariadb_backup_directory='{{ mariadb_backup_directory }}'
pid_file='{{ pid_file }}'
pid_file='{{ pid_file }}'
binlog_path='{{ binlog_path }}'
binlog_path='{{ binlog_path }}'
server_executable='{{ server_executable }}'
server_executable='{{ server_executable }}'
server_socket='{{ socket }}'
# Make sure mariadb is not already running
# Make sure mariadb is not already running
if [ -e "$pid_file" ]; then
if [ -e "$pid_file" ]; then
...
@@ -27,16 +31,7 @@ if [ -e "$pid_file" ]; then
...
@@ -27,16 +31,7 @@ if [ -e "$pid_file" ]; then
fi
fi
fi
fi
echo "EXISTING DATABASE CONTENT WILL BE DESTROYED"
echo "Deleting existing database..."
echo "You have 5 seconds to interrupt this script..."
if sleep 5; then
echo "Expired, proceeding"
else
echo "Interrupted, aborting"
exit 1
fi
echo "Emptying data directory..."
find "$mariadb_data_directory" -mindepth 1 -delete
find "$mariadb_data_directory" -mindepth 1 -delete
# $binlog_path can be empty if incremental_backup_retention_days <= -1
# $binlog_path can be empty if incremental_backup_retention_days <= -1
...
@@ -50,35 +45,24 @@ if [ -n "$binlog_path" ]; then
...
@@ -50,35 +45,24 @@ if [ -n "$binlog_path" ]; then
fi
fi
fi
fi
echo
-n "Starting mariadb for backup restoration
"
echo
"Starting mariadb...
"
"$server_executable" --innodb-flush-method=nosync --skip-innodb-doublewrite --innodb-flush-log-at-trx-commit=0 --sync-frm=0 --slow-query-log=0 --skip-log-bin &
"$server_executable" --innodb-flush-method=nosync --skip-innodb-doublewrite --innodb-flush-log-at-trx-commit=0 --sync-frm=0 --slow-query-log=0 --skip-log-bin &
mysqld_pid=$!
mysqld_pid=$!
trap "kill $mysqld_pid; wait; exit 1" EXIT TERM INT
trap "kill $mysqld_pid" EXIT TERM INT
while true; do
sleep 30
if [ ! -e "/proc/$mysqld_pid" ]; then
# If mysql has stopped, abort
trap EXIT TERM INT
if ! [ -d /proc/$mysql_pid ]; then
echo "Service exited, check logs"
echo "mysqld exited, aborting."
wait
exit 1
exit 1
fi
fi
if [ -e "$server_socket" ]; then
echo "started."
break
fi
echo -n .
sleep 0.5
done
echo "Importing $dump ..."
echo "Importing data..."
zcat "$dump" | "$mysql_executable" || {
# Use latest dump XXX can contain funny characters
dump=$(ls -r "$mariadb_backup_directory" | head -1)
zcat "$mariadb_backup_directory/$dump" | $mysql_executable || {
RESTORE_EXIT_CODE=$?
RESTORE_EXIT_CODE=$?
echo 'Backup restoration failed.'
echo 'Backup restoration failed.'
exit $RESTORE_EXIT_CODE
exit $RESTORE_EXIT_CODE
}
}
echo "Stopping mariadb..."
echo 'Backup restoration successfully completed.'
trap EXIT TERM INT
kill $mysqld_pid
wait
echo "Done. Start mariadb normally."
stack/erp5/instance-mariadb-start-clone-from-backup.sh.in
View file @
77e1da6b
...
@@ -7,48 +7,50 @@ if [ $# -ne 7 ]; then
...
@@ -7,48 +7,50 @@ if [ $# -ne 7 ]; then
exit 1
exit 1
fi
fi
dump
=$1
BACKUP
=$1
master_host
=$2
MASTER_HOST
=$2
master_port
=$3
MASTER_PORT
=$3
master_user
=$4
MASTER_USER
=$4
master_ssl_ca
=$5
MASTER_SSL_CA
=$5
master_ssl_cert
=$6
MASTER_SSL_CERT
=$6
master_ssl_key
=$7
MASTER_SSL_KEY
=$7
mysql_executable='{{ mysql_executable }}'
CLIENT='{{ client }}'
mariadb_data_directory='{{ data_directory }}'
DATA_DIRECTORY='{{ data_directory }}'
pid_file='{{ pid_file }}'
PID_FILE='{{ pid_file }}'
server_executable='{{ server_executable }}'
SERVER='{{ server }}'
server_socket='{{ socket }}'
UPDATE='{{ update }}'
SOCKET='{{ socket }}'
# Make sure mariadb is not already running
# Make sure mariadb is not already running
if [ -e "$pid_file" ]; then
if [ -e "$PID_FILE" ]; then
if ! pid=$(cat "$pid_file"); then
PID=$(cat "$PID_FILE")
if [ $? -ne 0 ]; then
echo "Cannot read Mariadb pidfile, assuming running. Aborting."
echo "Cannot read Mariadb pidfile, assuming running. Aborting."
exit 1
exit 1
fi
fi
if kill -0 "$
pid
"; then
if kill -0 "$
PID
"; then
echo "Mariadb is already running with pid $
pid
. Aborting."
echo "Mariadb is already running with pid $
PID
. Aborting."
exit 1
exit 1
fi
fi
fi
fi
backup_head="$(zcat "$dump
" | head -n 100)"
BACKUP_HEAD="$(zcat "$BACKUP
" | head -n 100)"
sql_change_master=$(printf "%s" "$backup_head
" | grep "^--\s*CHANGE MASTER TO " | sed "s/^--\s*//")
SQL_CHANGE_MASTER=$(echo "$BACKUP_HEAD
" | grep "^--\s*CHANGE MASTER TO " | sed "s/^--\s*//")
if [ -z "$
sql_change_master
" ]; then
if [ -z "$
SQL_CHANGE_MASTER
" ]; then
echo "'CHANGE MASTER TO' statement not found in given backup file."
echo "'CHANGE MASTER TO' statement not found in given backup file."
echo "Is replication enabled on future master ?"
echo "Is replication enabled on future master ?"
exit 1
exit 1
fi
fi
sql_set_gtid="$(printf "%s" "$backup_head
" | grep "^--\s*SET GLOBAL gtid_slave_pos=" | sed "s/^--\s*//")"
SQL_SET_GTID="$(echo "$BACKUP_HEAD
" | grep "^--\s*SET GLOBAL gtid_slave_pos=" | sed "s/^--\s*//")"
if [ -z "$
sql_set_gtid
" ]; then
if [ -z "$
SQL_SET_GTID
" ]; then
echo "Info: GTID not found in backup, it will not be enabled."
echo "Info: GTID not found in backup, it will not be enabled."
master_use_gtid
=0
MASTER_USE_GTID
=0
else
else
echo "Info: GTID found in backup, it will be enabled."
echo "Info: GTID found in backup, it will be enabled."
master_use_gtid
=1
MASTER_USE_GTID
=1
fi
fi
echo "EXISTING DATABASE CONTENT WILL BE DESTROYED"
echo "EXISTING DATABASE CONTENT WILL BE DESTROYED"
...
@@ -61,66 +63,61 @@ else
...
@@ -61,66 +63,61 @@ else
fi
fi
echo "Emptying data directory..."
echo "Emptying data directory..."
find "$
mariadb_data_directory
" -mindepth 1 -delete
find "$
DATA_DIRECTORY
" -mindepth 1 -delete
echo -n "Starting mariadb for backup restoration"
echo -n "Starting mariadb for backup restoration"
"$
server_executable
" --innodb-flush-method=nosync --skip-innodb-doublewrite --innodb-flush-log-at-trx-commit=0 --sync-frm=0 --slow-query-log=0 --skip-log-bin &
"$
SERVER
" --innodb-flush-method=nosync --skip-innodb-doublewrite --innodb-flush-log-at-trx-commit=0 --sync-frm=0 --slow-query-log=0 --skip-log-bin &
mysqld_pid
=$!
PID
=$!
trap "kill $
mysqld_pid; wait; exit 1" EXIT TERM IN
T
trap "kill $
PID; wait; exit 1" EXI
T
while true; do
while true; do
if [ ! -e "/proc/$
mysqld_pid
" ]; then
if [ ! -e "/proc/$
PID
" ]; then
trap EXIT
TERM INT
trap EXIT
echo "Service exited, check logs"
echo "Service exited, check logs"
wait
wait
exit 1
exit 1
fi
fi
if [ -e "$server_socket" ]; then
test -e "$SOCKET" && break
echo "started."
break
fi
echo -n .
echo -n .
sleep 0.5
sleep 0.5
done
done
echo "Importing $dump ..."
"$UPDATE"
zcat "$dump" | "$mysql_executable" || {
RESTORE_EXIT_CODE=$?
echo "Importing $BACKUP ..."
echo 'Backup restoration failed.'
zcat "$BACKUP" | "$CLIENT"
exit $RESTORE_EXIT_CODE
}
echo "Configuring server as slave..."
echo "Configuring server as slave..."
if [ "$
master_use_gtid
" -eq 1 ]; then
if [ "$
MASTER_USE_GTID
" -eq 1 ]; then
"$
mysql_executable" -e "$sql_set_gtid
"
"$
CLIENT" -e "$SQL_SET_GTID
"
maser_use_gtid_sql
="slave_pos"
MASTER_USE_GTID_SQL
="slave_pos"
else
else
maser_use_gtid_sql
="NO"
MASTER_USE_GTID_SQL
="NO"
fi
fi
"$
mysql_executable
" -e "
"$
CLIENT
" -e "
CHANGE MASTER TO
CHANGE MASTER TO
MASTER_HOST='$
master_host
',
MASTER_HOST='$
MASTER_HOST
',
MASTER_USER='$
master_user
',
MASTER_USER='$
MASTER_USER
',
MASTER_PORT=$
master_port
,
MASTER_PORT=$
MASTER_PORT
,
MASTER_SSL=1,
MASTER_SSL=1,
MASTER_SSL_CA='$
master_ssl_ca
',
MASTER_SSL_CA='$
MASTER_SSL_CA
',
MASTER_SSL_CERT='$
master_ssl_cert
',
MASTER_SSL_CERT='$
MASTER_SSL_CERT
',
MASTER_SSL_KEY='$
master_ssl_key
',
MASTER_SSL_KEY='$
MASTER_SSL_KEY
',
MASTER_SSL_VERIFY_SERVER_CERT=1,
MASTER_SSL_VERIFY_SERVER_CERT=1,
MASTER_USE_GTID=$
maser_use_gtid_sql
;
MASTER_USE_GTID=$
MASTER_USE_GTID_SQL
;
"
"
if [ "$
master_use_gtid
" -eq 0 ]; then
if [ "$
MASTER_USE_GTID
" -eq 0 ]; then
# No GTID, use binlog name & offset as provided by backup file.
# No GTID, use binlog name & offset as provided by backup file.
# Example: CHANGE MASTER TO MASTER_LOG_FILE='binlog.003447', MASTER_LOG_POS=360;
# Example: CHANGE MASTER TO MASTER_LOG_FILE='binlog.003447', MASTER_LOG_POS=360;
# Notes:
# Notes:
# - Must happen after setting
master_host & master_port
.
# - Must happen after setting
MASTER_HOST & MASTER_PORT
.
# - Implicitly sets
master_use_gtid
=NO if it was set before.
# - Implicitly sets
MASTER_USE_GTID
=NO if it was set before.
"$
mysql_executable" -e "$sql_change_master
"
"$
CLIENT" -e "$SQL_CHANGE_MASTER
"
fi
fi
"$
mysql_executable
" -e "START SLAVE;"
"$
CLIENT
" -e "START SLAVE;"
echo "Stopping mariadb..."
echo "Stopping mariadb..."
trap EXIT
TERM INT
trap EXIT
kill $
mysqld_pid
kill $
PID
wait
wait
echo "Done. Start mariadb normally. You may use 'show slave status' SQL command to monitor progress."
echo "Done. Start mariadb normally. You may use 'show slave status' SQL command to monitor progress."
stack/erp5/instance-mariadb.cfg.in
View file @
77e1da6b
...
@@ -275,11 +275,11 @@ url = {{ parameter_dict['mariadb-start-clone-from-backup'] }}
...
@@ -275,11 +275,11 @@ url = {{ parameter_dict['mariadb-start-clone-from-backup'] }}
output = ${directory:bin}/start-clone-from-backup
output = ${directory:bin}/start-clone-from-backup
context =
context =
key dash dash:dash
key dash dash:dash
key
mysql_executable
binary-wrap-mysql:wrapper-path
key
client
binary-wrap-mysql:wrapper-path
key data_directory my-cnf-parameters:data-directory
key data_directory my-cnf-parameters:data-directory
key pid_file my-cnf-parameters:pid-file
key pid_file my-cnf-parameters:pid-file
key server
_executable
mysqld:output
key server mysqld:output
key update
_executable
update-mysql:output
key update update-mysql:output
key socket my-cnf-parameters:socket
key socket my-cnf-parameters:socket
[{{ section('resiliency-after-import-script') }}]
[{{ section('resiliency-after-import-script') }}]
...
@@ -290,13 +290,11 @@ output = ${directory:bin}/restore-from-backup
...
@@ -290,13 +290,11 @@ output = ${directory:bin}/restore-from-backup
context =
context =
key dash dash:dash
key dash dash:dash
key mysql_executable binary-wrap-mysql:wrapper-path
key mysql_executable binary-wrap-mysql:wrapper-path
key data_directory my-cnf-parameters:data-directory
key
mariadb_
data_directory my-cnf-parameters:data-directory
key backup_directory directory:mariadb-backup-full
key
mariadb_
backup_directory directory:mariadb-backup-full
key pid_file my-cnf-parameters:pid-file
key pid_file my-cnf-parameters:pid-file
key binlog_path my-cnf-parameters:binlog-path
key binlog_path my-cnf-parameters:binlog-path
key server_executable mysqld:output
key server_executable mysqld:output
key update_executable update-mysql:output
key socket my-cnf-parameters:socket
[{{ section('monitor-generate-mariadb-slow-query-report') }}]
[{{ section('monitor-generate-mariadb-slow-query-report') }}]
recipe = slapos.cookbook:cron.d
recipe = slapos.cookbook:cron.d
...
...
stack/erp5/instance-zope.cfg.in
View file @
77e1da6b
...
@@ -500,7 +500,7 @@ wrapper-path = ${buildout:bin-directory}/runTestSuite
...
@@ -500,7 +500,7 @@ wrapper-path = ${buildout:bin-directory}/runTestSuite
{% do connection_string_list.append(
{% do connection_string_list.append(
'%s@%s:%s %s %s' % (
'%s@%s:%s %s %s' % (
parsed_url.path.lstrip('/'),
parsed_url.path.lstrip('/'),
'erp5-catalog-0'
,
parsed_url.hostname
,
parsed_url.port,
parsed_url.port,
parsed_url.username,
parsed_url.username,
parsed_url.password,
parsed_url.password,
...
...
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