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
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Rafael Monnerat
slapos
Commits
fb9451db
Commit
fb9451db
authored
Sep 20, 2019
by
Rafael Monnerat
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Edge Test
parent
61225b9a
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
351 additions
and
23 deletions
+351
-23
software/monitor/buildout.hash.cfg
software/monitor/buildout.hash.cfg
+42
-0
software/monitor/instance-default-input-schema.json
software/monitor/instance-default-input-schema.json
+10
-0
software/monitor/instance-default-output-schema.json
software/monitor/instance-default-output-schema.json
+11
-0
software/monitor/instance-edgetest-input-schema.json
software/monitor/instance-edgetest-input-schema.json
+10
-0
software/monitor/instance-edgetest-slave-input-schema.json
software/monitor/instance-edgetest-slave-input-schema.json
+10
-0
software/monitor/instance-monitor-bot.cfg.jinja2
software/monitor/instance-monitor-bot.cfg.jinja2
+60
-0
software/monitor/instance-monitor-edgetest.cfg.jinja2
software/monitor/instance-monitor-edgetest.cfg.jinja2
+144
-0
software/monitor/instance.cfg
software/monitor/instance.cfg
+22
-6
software/monitor/software.cfg
software/monitor/software.cfg
+13
-17
software/monitor/software.cfg.json
software/monitor/software.cfg.json
+29
-0
No files found.
software/monitor/buildout.hash.cfg
0 → 100644
View file @
fb9451db
# THIS IS NOT A BUILDOUT FILE, despite purposedly using a compatible syntax.
# The only allowed lines here are (regexes):
# - "^#" comments, copied verbatim
# - "^[" section beginings, copied verbatim
# - lines containing an "=" sign which must fit in the following categorie.
# - "^\s*filename\s*=\s*path\s*$" where "path" is relative to this file
# Copied verbatim.
# - "^\s*hashtype\s*=.*" where "hashtype" is one of the values supported
# by the re-generation script.
# Re-generated.
# - other lines are copied verbatim
# Substitution (${...:...}), extension ([buildout] extends = ...) and
# section inheritance (< = ...) are NOT supported (but you should really
# not need these here).
[template]
filename = instance.cfg
md5sum = 677f827c03309bdcecbc3c6405bd760c
[template-monitor]
filename = instance-monitor.cfg.jinja2
md5sum = dffe797be3a66d6838ffc70ee8f5f3ff
[template-monitor-edgetest]
filename = instance-monitor-edgetest.cfg.jinja2
md5sum = 4ff61df3f3823274d36c19521dc5a536
[template-monitor-bot]
filename = instance-monitor-bot.cfg.jinja2
md5sum = b1ea718c10c9c9b56a86caa2d3320ed7
[json-test-template]
filename = json-test-template.json.in.jinja2
md5sum = 2eb5596544d9c341acf653d4f7ce2680
[network-bench-cfg]
filename = network_bench.cfg.in
md5sum = cfcbf2002b8eff5153e2bf68ed24b720
[monitor-collect-csv-dump]
filename = script/collect_csv_dump.py
md5sum = cad2402bbd21907cfed6bc5af8c5d3ab
software/monitor/instance-default-input-schema.json
0 → 100644
View file @
fb9451db
{
"$schema"
:
"http://json-schema.org/draft-04/schema#"
,
"properties"
:
{
"dummy"
:
{
"title"
:
"dummy"
,
"description"
:
"Dummy"
,
"type"
:
"string"
}
}
}
software/monitor/instance-default-output-schema.json
0 → 100644
View file @
fb9451db
{
"$schema"
:
"http://json-schema.org/draft-04/schema#"
,
"description"
:
"Values returned by Re6st Master instanciation"
,
"properties"
:
{
"re6stry-url"
:
{
"description"
:
"ipv6 url to access your re6st registry service"
,
"type"
:
"string"
}
},
"type"
:
"object"
}
software/monitor/instance-edgetest-input-schema.json
0 → 100644
View file @
fb9451db
{
"$schema"
:
"http://json-schema.org/draft-04/schema#"
,
"properties"
:
{
"dummy"
:
{
"title"
:
"dummy"
,
"description"
:
"Dummy"
,
"type"
:
"string"
}
}
}
software/monitor/instance-edgetest-slave-input-schema.json
0 → 100644
View file @
fb9451db
{
"$schema"
:
"http://json-schema.org/draft-04/schema#"
,
"properties"
:
{
"dummy"
:
{
"title"
:
"dummy"
,
"description"
:
"Dummy"
,
"type"
:
"string"
}
}
}
software/monitor/instance-monitor-bot.cfg.jinja2
0 → 100644
View file @
fb9451db
{% set slave_instance_list = [] %}
{% set extra_slave_instance_list = slapparameter_dict.get('extra_slave_instance_list') %}
{% if extra_slave_instance_list %}
{% set slave_instance_list = json_module.loads(extra_slave_instance_list) %}
{% endif %}
[buildout]
extends = {{ monitor_template_output }}
parts =
cron
monitor-base
publish-connection-information
eggs-directory = {{ eggs_directory }}
develop-eggs-directory = {{ develop_eggs_directory }}
offline = true
[publish-connection-information]
recipe = slapos.cookbook:publish.serialised
monitor-base-url = ${monitor-publish-parameters:monitor-base-url}
monitor-url = ${monitor-publish-parameters:monitor-url}
monitor-user = ${monitor-publish-parameters:monitor-user}
monitor-password = ${monitor-publish-parameters:monitor-password}
[monitor-instance-parameter]
cors-domains = {{ slapparameter_dict.get('monitor-cors-domains', 'monitor.app.officejs.com') }}
{% if slapparameter_dict.get('monitor-username', '') -%}
username = {{ slapparameter_dict['monitor-username'] }}
{% endif -%}
{% if slapparameter_dict.get('monitor-password', '') -%}
password = {{ slapparameter_dict['monitor-password'] }}
{% endif -%}
interface-url = {{ slapparameter_dict.get('monitor-interface-url', 'https://monitor.app.officejs.com') }}
[monitor-directory]
service = ${buildout:directory}/etc/service
var = ${buildout:directory}/var
srv = ${buildout:directory}/srv
server-log = ${:private}/server-log
monitor-log = ${:private}/monitor-log
cache = ${:var}/cache
mod-ssl = ${:cache}/httpd_mod_ssl
[python-symlink]
recipe = plone.recipe.command
command = ln -sf {{ buildout_bin }}/pythonwitheggs ${monitor-directory:bin}/python
update-command = ${:command}
[slap-configuration]
recipe = slapos.cookbook:slapconfiguration.serialised
computer = ${slap-connection:computer-id}
partition = ${slap-connection:partition-id}
url = ${slap-connection:server-url}
key = ${slap-connection:key-file}
cert = ${slap-connection:cert-file}
[slap-parameter]
software/monitor/instance-monitor-
distributor
.cfg.jinja2
→
software/monitor/instance-monitor-
edgetest
.cfg.jinja2
View file @
fb9451db
...
@@ -9,7 +9,7 @@ context =
...
@@ -9,7 +9,7 @@ context =
[slave-test-configuration]
[slave-test-configuration]
<=jinja2-template-base
<=jinja2-template-base
template = {{ template_json_
distributor
_test }}
template = {{ template_json_
edgetest
_test }}
filename = srv/monitor/private/test.json
filename = srv/monitor/private/test.json
extensions = jinja2.ext.do
extensions = jinja2.ext.do
extra-context =
extra-context =
...
@@ -17,6 +17,66 @@ extra-context =
...
@@ -17,6 +17,66 @@ extra-context =
{% set part_list = [] -%}
{% set part_list = [] -%}
# Publish information for each slave
# Publish information for each slave
{% set bot_software_type = 'bot' %}
{% set bot_quantity = slapparameter_dict.pop('bot-quantity', '1') | int %}
{% set bot_list = [] %}
{% set bot_section_list = [] %}
{% set slave_list_name = 'extra_slave_instance_list' %}
{% set request_dict = {} %}
{% set namebase = "bot" %}
{% set authorized_slave_list = [] %}
{% set monitor_base_url_dict = {} -%}
{% for slave in sorted(slave_instance_list) %}
{% do authorized_slave_list.append(slave) %}
{% endfor %}
{% for i in range(1, bot_quantity + 1) %}
{% set bot_name = "%s-%s" % (namebase, i) %}
{% set request_section_title = 'request-%s' % bot_name %}
{% do bot_list.append(bot_name) %}
{% do bot_section_list.append(request_section_title) %}
{% do part_list.append(request_section_title) %}
{% do request_dict.__setitem__(request_section_title,
{
'config': {},
'name': bot_name,
'sla': {},
'state': 'started',
}) %}
{% endfor %}
[replicate]
<= slap-connection
recipe = slapos.cookbook:request.serialised
config-monitor-cors-domains = {{ slapparameter_dict.get('monitor-cors-domains', 'monitor.app.officejs.com') }}
config-monitor-username = ${monitor-instance-parameter:username}
config-monitor-password = ${monitor-htpasswd:passwd}
software-url = ${slap-connection:software-release-url}
software-type = {{bot_software_type}}
return = monitor-base-url
{% for section, bot_request in request_dict.iteritems() %}
[{{section}}]
<= replicate
name = {{ bot_request.get('name') }}
{% if bot_request.get('state') %}
state = {{ bot_request.get('state') }}
{% endif%}
{% set slave_configuration_dict = slapparameter_dict %}
{% do slave_configuration_dict.update(bot_request.get('config')) %}
{% do slave_configuration_dict.__setitem__(slave_list_name, json_module.dumps(authorized_slave_list)) %}
{%- for config_key, config_value in slave_configuration_dict.iteritems() %}
config-{{ config_key }} = {{ dumps(config_value) }}
{% endfor -%}
{% if bot_request.get('sla') %}
{% for parameter, value in bot_request.get('sla').iteritems() %}
sla-{{ parameter }} = {{ value }}
{% endfor %}
{% endif %}
{% do monitor_base_url_dict.__setitem__(section, '${' ~ section ~ ':connection-monitor-base-url}') -%}
{% endfor %}
{% set directory_list = [] -%}
{% set directory_list = [] -%}
...
@@ -26,8 +86,6 @@ extra-context =
...
@@ -26,8 +86,6 @@ extra-context =
[{{ publish_section_title }}]
[{{ publish_section_title }}]
recipe = slapos.cookbook:publish
recipe = slapos.cookbook:publish
-slave-reference = {{ slave_instance.get('slave_reference') }}
-slave-reference = {{ slave_instance.get('slave_reference') }}
log-access-url = ${monitor-frontend:connection-site_url}/{{ slave_instance.get('slave_reference') }}
log-access-url-v6 = ${monitor-httpd-conf-parameter:url}/{{ slave_instance.get('slave_reference') }}
{% endfor %}
{% endfor %}
...
@@ -61,6 +119,14 @@ user-log-{{ slave_instance.get('slave_reference') }}-ping6-folder = ${:private}/
...
@@ -61,6 +119,14 @@ user-log-{{ slave_instance.get('slave_reference') }}-ping6-folder = ${:private}/
{{ '%s = ${:crawl-log}/%s' % (directory, directory) }}
{{ '%s = ${:crawl-log}/%s' % (directory, directory) }}
{% endfor %}
{% endfor %}
[monitor-conf-parameters]
monitor-title = Monitor
password = ${monitor-htpasswd:passwd}
[monitor-base-url-dict]
{% for key, value in monitor_base_url_dict.items() -%}
{{ key }} = {{ value }}
{% endfor %}
[crawler-bin]
[crawler-bin]
recipe = slapos.cookbook:wrapper
recipe = slapos.cookbook:wrapper
...
...
software/monitor/instance.cfg
View file @
fb9451db
...
@@ -8,11 +8,12 @@ develop-eggs-directory = ${buildout:develop-eggs-directory}
...
@@ -8,11 +8,12 @@ develop-eggs-directory = ${buildout:develop-eggs-directory}
[switch_softwaretype]
[switch_softwaretype]
recipe = slapos.cookbook:softwaretype
recipe = slapos.cookbook:softwaretype
default = $${instance-base-monitor:rendered}
default = $${instance-base-monitor:rendered}
distributor = $${instance-base-distributor:rendered}
edgetest = $${instance-base-edgetest:rendered}
bot = $${instance-base-bot:rendered}
[instance-base-monitor]
[instance-base-monitor]
recipe = slapos.recipe.template:jinja2
recipe = slapos.recipe.template:jinja2
template = ${template-monitor:
destination
}
template = ${template-monitor:
target
}
rendered = $${buildout:directory}/template-base-monitor.cfg
rendered = $${buildout:directory}/template-base-monitor.cfg
extensions = jinja2.ext.do
extensions = jinja2.ext.do
context = key develop_eggs_directory buildout:develop-eggs-directory
context = key develop_eggs_directory buildout:develop-eggs-directory
...
@@ -24,10 +25,10 @@ context = key develop_eggs_directory buildout:develop-eggs-directory
...
@@ -24,10 +25,10 @@ context = key develop_eggs_directory buildout:develop-eggs-directory
raw monitor_collect_csv_dump ${monitor-collect-csv-dump:output}
raw monitor_collect_csv_dump ${monitor-collect-csv-dump:output}
mode = 0644
mode = 0644
[instance-base-
distributor
]
[instance-base-
edgetest
]
recipe = slapos.recipe.template:jinja2
recipe = slapos.recipe.template:jinja2
template = ${template-monitor-
distributor:destination
}
template = ${template-monitor-
edgetest:target
}
rendered = $${buildout:directory}/template-monitor-base-
distributor
.cfg
rendered = $${buildout:directory}/template-monitor-base-
edgetest
.cfg
extensions = jinja2.ext.do
extensions = jinja2.ext.do
context = import json_module json
context = import json_module json
key develop_eggs_directory buildout:develop-eggs-directory
key develop_eggs_directory buildout:develop-eggs-directory
...
@@ -36,10 +37,25 @@ context = import json_module json
...
@@ -36,10 +37,25 @@ context = import json_module json
key instance_base_monitor instance-base-monitor:rendered
key instance_base_monitor instance-base-monitor:rendered
key slave_instance_list slap-configuration:slave-instance-list
key slave_instance_list slap-configuration:slave-instance-list
raw buildout_bin ${buildout:bin-directory}
raw buildout_bin ${buildout:bin-directory}
raw template_json_
distributor_test ${json-test-template:destination
}
raw template_json_
edgetest_test ${json-test-template:target
}
raw wget_bin ${wget:location}/bin/wget
raw wget_bin ${wget:location}/bin/wget
mode = 0644
mode = 0644
[instance-base-bot]
recipe = slapos.recipe.template:jinja2
template = ${template-monitor-bot:target}
rendered = $${buildout:directory}/template-monitor-bot.cfg
extensions = jinja2.ext.do
context = import json_module json
key develop_eggs_directory buildout:develop-eggs-directory
key eggs_directory buildout:eggs-directory
key slapparameter_dict slap-configuration:configuration
raw buildout_bin ${buildout:bin-directory}
raw monitor_template_output ${monitor-template:output}
raw monitor_collect_csv_dump ${monitor-collect-csv-dump:output}
mode = 0644
[slap-configuration]
[slap-configuration]
recipe = slapos.cookbook:slapconfiguration.serialised
recipe = slapos.cookbook:slapconfiguration.serialised
computer = $${slap-connection:computer-id}
computer = $${slap-connection:computer-id}
...
...
software/monitor/software.cfg
View file @
fb9451db
[buildout]
[buildout]
extends =
extends =
buildout.hash.cfg
../../component/pycurl/buildout.cfg
../../component/pycurl/buildout.cfg
../../component/python-cryptography/buildout.cfg
../../component/python-cryptography/buildout.cfg
../../component/wget/buildout.cfg
../../component/wget/buildout.cfg
...
@@ -13,7 +14,7 @@ parts =
...
@@ -13,7 +14,7 @@ parts =
network-bench-cfg
network-bench-cfg
json-test-template
json-test-template
template
template
template-monitor-
distributor
template-monitor-
edgetest
template-monitor
template-monitor
monitor-collect-csv-dump
monitor-collect-csv-dump
...
@@ -21,35 +22,32 @@ parts =
...
@@ -21,35 +22,32 @@ parts =
recipe = slapos.recipe.template
recipe = slapos.recipe.template
url = ${:_profile_base_location_}/instance.cfg
url = ${:_profile_base_location_}/instance.cfg
output = ${buildout:directory}/template.cfg
output = ${buildout:directory}/template.cfg
md5sum = 1b7d2d097f208f6641bf98a17df079c8
mode = 0644
mode = 0644
[template-monitor]
[template-monitor]
recipe = slapos.recipe.build:download
recipe = slapos.recipe.build:download
url = ${:_profile_base_location_}/instance-monitor.cfg.jinja2
url = ${:_profile_base_location_}/${:filename}
destination = ${buildout:directory}/template-base-monitor.cfg
md5sum = dffe797be3a66d6838ffc70ee8f5f3ff
mode = 0644
mode = 0644
[template-monitor-
distributor
]
[template-monitor-
edgetest
]
recipe = slapos.recipe.build:download
recipe = slapos.recipe.build:download
url = ${:_profile_base_location_}/instance-monitor-distributor.cfg.jinja2
url = ${:_profile_base_location_}/${:filename}
destination = ${buildout:directory}/template-monitor-base-distributor.cfg
mode = 0644
md5sum = 61c0bfdfc0a2b51ba15fe4a49baf6091
[template-monitor-bot]
recipe = slapos.recipe.build:download
url = ${:_profile_base_location_}/${:filename}
mode = 0644
mode = 0644
[json-test-template]
[json-test-template]
recipe = slapos.recipe.build:download
recipe = slapos.recipe.build:download
url = ${:_profile_base_location_}/json-test-template.json.in.jinja2
url = ${:_profile_base_location_}/${:filename}
destination = ${buildout:directory}/json-test-template.json.in.jinja2
md5sum = 2eb5596544d9c341acf653d4f7ce2680
mode = 0644
mode = 0644
[network-bench-cfg]
[network-bench-cfg]
recipe = slapos.recipe.template
recipe = slapos.recipe.template
url = ${:_profile_base_location_}/network_bench.cfg.in
url = ${:_profile_base_location_}/${:filename}
md5sum = cfcbf2002b8eff5153e2bf68ed24b720
output = ${buildout:parts-directory}/${:_buildout_section_name_}
output = ${buildout:directory}/template-network-bench-cfg.in
mode = 0644
mode = 0644
[monitor-collect-csv-dump]
[monitor-collect-csv-dump]
...
@@ -57,7 +55,6 @@ mode = 0644
...
@@ -57,7 +55,6 @@ mode = 0644
url = ${:_profile_base_location_}/script/${:filename}
url = ${:_profile_base_location_}/script/${:filename}
filename = collect_csv_dump.py
filename = collect_csv_dump.py
output = ${:destination}/${:filename}
output = ${:destination}/${:filename}
md5sum = cad2402bbd21907cfed6bc5af8c5d3ab
[extra-eggs]
[extra-eggs]
<= monitor-eggs
<= monitor-eggs
...
@@ -86,6 +83,5 @@ eggs +=
...
@@ -86,6 +83,5 @@ eggs +=
hexagonit.recipe.download
hexagonit.recipe.download
plone.recipe.command
plone.recipe.command
[versions]
[versions]
slapos.recipe.template = 4.3
slapos.recipe.template = 4.3
software/monitor/software.cfg.json
0 → 100644
View file @
fb9451db
{
"name"
:
"Monitor"
,
"description"
:
"Software release for Monitoring purpose"
,
"serialisation"
:
"xml"
,
"software-type"
:
{
"default"
:
{
"title"
:
"Default"
,
"description"
:
"Standalone Monitor"
,
"request"
:
"instance-default-input-schema.json"
,
"response"
:
"instance-default-output-schema.json"
,
"index"
:
0
},
"edgetest"
:
{
"title"
:
"Edge Test"
,
"description"
:
"Cluster of bots to perform a distributed monitoring "
,
"request"
:
"instance-edgetest-input-schema.json"
,
"response"
:
"instance-default-output-schema.json"
,
"index"
:
1
},
"edgetest-slave"
:
{
"title"
:
"Edge Test Case"
,
"software-type"
:
"edgetest"
,
"description"
:
"Cluster of bots to perform a distributed monitoring "
,
"request"
:
"instance-edgetest-slave-input-schema.json"
,
"response"
:
"instance-default-output-schema.json"
,
"index"
:
1
}
}
}
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