blob: e31670db484a1718f75d9dd7fa3b854b8ad4ad79 [file] [log] [blame]
Patrick Williamsc124f4f2015-09-15 14:41:29 -05001# Copyright (C) 2014 Intel Corporation
2#
3# Released under the MIT license (see COPYING.MIT)
4
5# This module adds support to testimage.bbclass to deploy images and run
6# tests on a Ubiquiti Networks EdgeRouter Lite. The device must be set up
7# to boot into the master image already - the easiest way to do that is as
8# follows:
9#
10# 1. Take out the internal USB drive and plug it into your PC
11# 2. Repartition the USB drive so that you have three partitions in this
12# order:
13# 1: vfat, labelled "boot" (it will need to be formatted with mkfs.vfat
14# for this to be possible, since FAT partitions formatted under
15# DOS/Windows will only support uppercase labels)
16# 2: ext3 (for master image) labelled "testmaster"
17# 3: ext3 (for image under test) labelled "testrootfs"
18# 3. Copy the kernel to be used by the master image to the FAT partition
19# (it should be named "vmlinux.64" with the factory u-boot configuration)
20# 4. Install the master image onto the "testmaster" ext3 partition. If
21# you do this by just extracting the contents of an image onto the
22# partition, you will also likely need to create the master image marker
23# file /etc/masterimage within this partition so that we can tell when
24# we're booted into it that it is the master image.
25# 5. Put the USB drive back into the device, and ensure the console port
26# and first ethernet port are connected before powering on
27#
28# TEST_SERIALCONTROL_CMD will need to be set in local.conf so that we can
29# interact with u-boot over the serial console port.
30
31import os
32import bb
33import time
34import subprocess
35import sys
36import pexpect
37
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000038from oeqa.controllers.controllerimage import ControllerImageHardwareTarget
Patrick Williamsc124f4f2015-09-15 14:41:29 -050039
40
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000041class EdgeRouterTarget(ControllerImageHardwareTarget):
Patrick Williamsc124f4f2015-09-15 14:41:29 -050042
43 def __init__(self, d):
44 super(EdgeRouterTarget, self).__init__(d)
45
Brad Bishop37a0e4d2017-12-04 01:01:44 -050046 self.image_fstype = self.get_image_fstype(d)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050047 self.deploy_cmds = [
48 'mount -L boot /boot',
49 'mkdir -p /mnt/testrootfs',
50 'mount -L testrootfs /mnt/testrootfs',
51 'cp ~/test-kernel /boot',
52 'rm -rf /mnt/testrootfs/*',
53 'tar xvf ~/test-rootfs.%s -C /mnt/testrootfs' % self.image_fstype
54 ]
55 if not self.serialcontrol_cmd:
56 bb.fatal("This TEST_TARGET needs a TEST_SERIALCONTROL_CMD defined in local.conf.")
57
58
59 def _deploy(self):
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000060 self.controller.run("umount /mnt/testrootfs;")
61 self.controller.ignore_status = False
62 self.controller.copy_to(self.kernel, "~/test-kernel")
63 self.controller.copy_to(self.rootfs, "~/test-rootfs.%s" % self.image_fstype)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050064 for cmd in self.deploy_cmds:
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000065 self.controller.run(cmd)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050066
67 def _start(self, params=None):
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000068 self.power_cycle(self.controller)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050069 try:
70 serialconn = pexpect.spawn(self.serialcontrol_cmd, env=self.origenv, logfile=sys.stdout)
71 serialconn.expect("U-Boot")
72 serialconn.sendline("a")
73 serialconn.expect("Octeon ubnt_e100#")
74 serialconn.sendline("fatload usb 0:1 $loadaddr test-kernel")
75 serialconn.expect(" bytes read")
76 serialconn.expect("Octeon ubnt_e100#")
77 serialconn.sendline("bootoctlinux $loadaddr coremask=0x3 root=/dev/sda3 rw rootwait mtdparts=phys_mapped_flash:512k(boot0),512k(boot1),64k@3072k(eeprom)")
78 serialconn.expect("login:", timeout=120)
79 serialconn.close()
80 except pexpect.ExceptionPexpect as e:
81 bb.fatal('Serial interaction failed: %s' % str(e))
82
83 def _wait_until_booted(self):
84 try:
85 serialconn = pexpect.spawn(self.serialcontrol_cmd, env=self.origenv, logfile=sys.stdout)
86 serialconn.expect("login:", timeout=120)
87 serialconn.close()
88 except pexpect.ExceptionPexpect as e:
89 bb.fatal('Serial interaction failed: %s' % str(e))