aboutsummaryrefslogtreecommitdiff
path: root/rumba
Commit message (Collapse)AuthorAgeFilesLines
* SSH: added stderr to output in case of commmand errorMarco Capitani2017-11-091-2/+9
|
* prototypes: Always parse manifest for hostnameDimitri Staessens2017-11-091-12/+3
| | | | | The hostname for wall1 nodes was wrongly constructed. We now parse the manifest for all testbeds to get the hostname.
* prototypes: rlite: use the retry version of enrollment commandVincenzo Maffione2017-11-091-1/+1
| | | | This is useful if enrollment fails because of packet loss.
* prototypes: Update IRATI installDimitri Staessens2017-11-091-2/+2
| | | | The package versions specified give conflicts on Ubuntu.
* testbeds: Fix check for physical machinesDimitri Staessens2017-10-301-1/+1
| | | | | | The check for the value of the "exclusive" attribute was comparing to the boolean True instead of the string "true", causing the selection of default VM images regardless of this setting.
* rumba: Add persistent SSH connectionsSander Vrijders2017-10-262-23/+23
| | | | | | This adds persistent SSH connections to Rumba. A new SSH client will be opened for every node in the experiment, which is closed after all experimentation is done.
* ssh_support: Close ssh clients properlySander Vrijders2017-10-261-11/+24
| | | | | | | The proxy client was not closed after the command has executed, and in case of an error condition the regular client was also not closed. Fixes #25
* prototypes, testbeds, ssh_support: Add several fixesSander Vrijders2017-10-254-32/+26
| | | | | This adds several fixes in order for rlite to function on the exogeni testbed.
* testbeds: Complete support for exogeni VMs on jfedDimitri Staessens2017-10-252-11/+37
| | | | Selecting "exogeni.net" as an authority for jfed should now work.
* ssh_support: Use native Paramiko API for ProxySander Vrijders2017-10-243-38/+31
| | | | | | This uses the native paramiko API for proxycommands instead of invoking OpenSSH on the host after connecting to it since that gives race conditons with Paramiko.
* testbeds: Add support for selecting jfed VMsDimitri Staessens2017-10-242-6/+33
| | | | | | | | | | Allows setting the attribute machine_type="virtual" for experiment nodes. If the attribute is set to something else than "virtual" a bare metal machine will be selected. If the attribute is not set, the default will be chosen from the jfed testbed. For the wall and cloudlab, the default is physical machines, for the others, it's virtual machines. This default can be overriden by setting the jfed testbed attribute use_physical_machines to True or False.
* testbeds: Fix image selection for jFeddimitri staessens2017-10-181-2/+12
| | | | | The rspec for node images seems to work on all emulab instances if the user is emulab-ops. Tested on cloudlab and virtual wall.
* prototypes: rlite: align to the new rlite releaseVincenzo Maffione2017-10-052-3/+8
|
* Model: add check for disconnected difMarco Capitani2017-09-261-0/+2
|
* examples: Add snake exampleSander Vrijders2017-09-201-1/+1
| | | | | This adds the snake as an example. It forms a single DIF connected node by node. The number of nodes can be passed as parameter.
* testbeds: qemu: Remove unneeded sleepSander Vrijders2017-09-202-3/+1
| | | | | This removes a sleep in the QEMU testbed that was giving errors. It also catches another error in the SSH support.
* Merge branch 'add-irati-ctrl' into 'master'Sander Vrijders2017-09-191-0/+3
|\ | | | | | | | | IRATI: added chmod for /dev/irati-ctrl See merge request arcfire/rumba!69
| * Irati: typo fixMarco Capitani2017-09-191-1/+1
| |
| * IRATI: added chmod for /dev/irati-ctrlMarco Capitani2017-09-191-0/+3
| |
* | Merge branch 'qemu-issue-#21' into 'master'Sander Vrijders2017-09-191-2/+20
|\ \ | | | | | | | | | | | | | | | | | | qemu: added check for timeout and interruption of swap-in processes Closes #21 See merge request arcfire/rumba!71
| * | qemu: added check for timeout and interruption of swap-in processesMarco Capitani2017-09-191-2/+20
| |/
* / model-storyboard: do not fail if a storyboard-related SSH fails.Marco Capitani2017-09-191-6/+29
|/
* Merge branch 'emulab-fix' into 'master'MCapitani2017-09-184-10/+48
|\ | | | | | | | | testbeds: emulab: Continue if experiment is swapped in See merge request arcfire/rumba!68
| * testbeds: jFed: Add swap_out methodSander Vrijders2017-09-181-0/+6
| | | | | | | | This implements the swap_out method for the jFed plugin.
| * testbeds: emulab: Continue if experiment is swapped inSander Vrijders2017-09-183-10/+42
| | | | | | | | | | | | This will let rumba continue if the experiment is already swapped in in emulab, since it is not an error. It also adds the posibility to swap the experiment out from Rumba.
* | IRATI: fix for variable installpathMarco Capitani2017-09-182-13/+18
|/
* rumba: Add better error handling of SSH connectSander Vrijders2017-09-153-24/+45
| | | | | | If an SSH connect doesn't succeed at first, it is retried up to 5 times with an exponential backoff. It also adds an error message in case of an offending host key.
* Merge branch 'dt-mgmt-enroll-split' into 'master'MCapitani2017-09-132-27/+71
|\ | | | | | | | | model: Perform split between different flows See merge request !64
| * model: Perform split between different flowsSander Vrijders2017-09-122-27/+71
| | | | | | | | | | This performs a split between enrollment, data transfer and management flows.
* | build: Add continuous integrationSander Vrijders2017-09-134-41/+76
| | | | | | | | This adds CI to Rumba.
* | Merge branch 'qemu-fix' into 'master'Sander Vrijders2017-09-121-5/+5
|\ \ | |/ |/| | | | | testbeds: qemu: Add dev option to ip link set See merge request !62
| * testbeds: qemu: Add dev option to ip link setSander Vrijders2017-09-041-5/+5
| | | | | | | | | | If the dev option is omitted, the command may fail on short names that resemble options.
* | prototypes: Fix enroll.pySander Vrijders2017-09-121-0/+1
| | | | | | | | | | enroll.py was missing the correct program to execute when executed via the shell. bash was assumed while Python was needed.
* | Merge branch 'master' of gitlab.com:arcfire/rumbaSander Vrijders2017-09-081-0/+3
|\ \
| * | qemu: fix for zombie processesMarco Capitani2017-09-061-0/+3
| |/
* / rumba: Update license headersSander Vrijders2017-09-0816-44/+235
|/ | | | | This makes the license headers uniform and adds the authors and a copyright.
* Model & ssh: ssh-related methods renamingMarco Capitani2017-07-284-16/+14
|
* model: Fixed some commentsMarco Capitani2017-07-281-2/+0
|
* Merge branch 'master' into storyboard-implMarco Capitani2017-07-284-32/+50
|\
| * rumba: Better placement of files created by RumbaSander Vrijders2017-06-194-32/+48
| | | | | | | | | | | | | | | | | | Temporary files such as ssh_info, the rspecs, logs, ... are now created in /tmp/rumba to avoid too many files being created and never removed. The VM images and jFed CLI are kept in ~/.cache/rumba to avoid redownloading every reboot. Closes #18, #19
* | ssh & model-storyboard: changed ssh API, added node.execute* methodsMarco Capitani2017-06-306-46/+172
| |
* | Storyboard testedMarco Capitani2017-06-221-12/+28
| |
* | Merge branch 'master' into storyboard-implMarco Capitani2017-06-219-38/+162
|\|
| * irati: update kernel versionVincenzo Maffione2017-06-151-1/+1
| |
| * Merge branch 'policies' into 'master'Vincenzo Maffione2017-06-154-27/+139
| |\ | | | | | | | | | | | | Add per-node policy management See merge request !44
| | * IRATI: added per-node policy support, and revamped policy data model.Marco Capitani2017-06-134-31/+77
| | | | | | | | | | | | | | | | | | additional: + fixed small bug rlated to vhost checking in qemu. + example scripts now correctly use policies.
| | * Merge branch 'master' into policiesMarco Capitani2017-06-138-136/+366
| | |\
| | * | model: added policy class + policy-oriented API fixesMarco Capitani2017-04-281-11/+76
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | + Added policy class + Adapted NormalDIF class to use new policy class + NormalDIF constructor argument policy has changed format (parameters dict is now mandatory, added empty dicts where it was not passed) + Added Node.policies field (type: dict[DIF -> Policy])
| * | | rumba: prototypes: Fix bad indentationSander Vrijders2017-06-151-1/+1
| | | |
| * | | prototypes: ouroboros: use isinstance() rather than type()Sander Vrijders2017-06-151-3/+3
| | | | | | | | | | | | | | | | This is convenient for compatibility between Python 2 and 3.