-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathraspberrypi3.robot
66 lines (65 loc) · 3.57 KB
/
raspberrypi3.robot
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
*** Settings ***
Documentation Resin device test example for raspberrypi3 - Please run with "--exitonerror"
Resource resources/resincli.robot
Resource resources/resinos.robot
Resource resources/kernel.robot
Library libraries/RigControl.py device_id=%{rig_device_id}
Suite Teardown Disable DUT
... AND Remove Files /tmp/resin*.img /tmp/autohat.*.stdout /tmp/autohat.*.stderr
*** Test Cases ***
Preparing test environment
Set Suite Variable ${requests_verify} %{requests_verify}
Set Suite Variable ${proxy_ssh_port} %{proxy_ssh_port}
Set Suite Variable ${application_name} %{application_name}
Set Suite Variable ${device_type} %{device_type}
Set Suite Variable ${BALENARC_BALENA_URL} %{BALENARC_BALENA_URL}
Set Suite Variable ${BALENARC_PROXY_URL} %{BALENARC_PROXY_URL}
Set Suite Variable ${image} %{image}
File Should Exist ${image} msg="Provided images file does not exist"
Set Suite Variable ${application_repo} https://github.com/resin-io/autohat-ondevice.git
Set Suite Variable ${application_commit} 430cbe53d5582a03a503357e7cfde90d3aa8aee2
Resin login with email "%{email}" and password "%{password}"
Set Suite Variable ${rig_sd_card} %{rig_sd_card}
${create_application} = Get Environment Variable CREATE_APPLICATION default=True
Set Suite Variable ${create_application} ${create_application}
Disable DUT
Adding new SSH key
Add new SSH key with name "${application_name}"
Deleting application if it already exists
Run Keyword If '${create_application}' == 'True' Force delete application "${application_name}"
Creating application
Run Keyword If '${create_application}' == 'True' Create application "${application_name}" with device type "${device_type}"
Checking host OS fingerprint file
Check host OS fingerprint file in "${image}"
Getting host OS version of the image
${return_os_version} = Get host OS version of "${image}"
Set Suite Variable ${os_version} ${return_os_version}
#Enabling getty service on the image
# Enable getty service on "${image}" for "${device_type}"
Configuring image with application
${device_uuid} = Configure "${image}" with "${application_name}"
Set Suite Variable ${device_uuid} ${device_uuid}
Running image
${result} = Run Bufferred Process etcher --drive $(realpath ${rig_sd_card}) --yes ${image} shell=yes
Process ${result}
Enable DUT
Checking if device comes online in 60s (Trying every 10s)
Wait Until Keyword Succeeds 6x 10s Device "${device_uuid}" is online
Git pushing to application
Git clone "${application_repo}" "/tmp/${application_name}"
Git checkout "${application_commit}" "/tmp/${application_name}"
Git push "/tmp/${application_name}" to application "${application_name}"
Checking if device is running the pushed application (Tries for 300 s)
Wait Until Keyword Succeeds 30x 10s Device "${device_uuid}" log should contain "Hello"
Checking if kernel module loading works
Check if kernel module loading works on "${device_uuid}"
#Checking delta to a running supervisor
# Check enabling supervisor delta on "${application_name}"
Checking if SSH works
Check if SSH works on "${device_uuid}"
Checking if setting environment variable works
Check if setting environment variables works on "${application_name}"
Checking if host OS version of the image is same through resin cli
Check if host OS version of device "${device_uuid}" is "${os_version}"
#Checking that backup files are not found in the image
# Check that backup files are not found in the "${image}"