| import os |
| |
| import infra.basetest |
| |
| |
| class TestOctave(infra.basetest.BRTest): |
| # infra.basetest.BASIC_TOOLCHAIN_CONFIG cannot be used as it does |
| # not include gfortran. |
| config = \ |
| """ |
| BR2_aarch64=y |
| BR2_TOOLCHAIN_EXTERNAL=y |
| BR2_TARGET_GENERIC_GETTY_PORT="ttyAMA0" |
| BR2_LINUX_KERNEL=y |
| BR2_LINUX_KERNEL_CUSTOM_VERSION=y |
| BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE="5.15.26" |
| BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG=y |
| BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE="board/qemu/aarch64-virt/linux.config" |
| BR2_LINUX_KERNEL_NEEDS_HOST_OPENSSL=y |
| BR2_TARGET_ROOTFS_CPIO=y |
| BR2_TARGET_ROOTFS_CPIO_GZIP=y |
| # BR2_TARGET_ROOTFS_TAR is not set |
| BR2_PACKAGE_OCTAVE=y |
| """ |
| timeout = 60 |
| |
| def octave_cmd(self, octave_expr): |
| return "octave --quiet --eval '{}'".format(octave_expr) |
| |
| def test_run(self): |
| img = os.path.join(self.builddir, "images", "rootfs.cpio.gz") |
| kern = os.path.join(self.builddir, "images", "Image") |
| self.emulator.boot(arch="aarch64", |
| kernel=kern, |
| kernel_cmdline=["console=ttyAMA0"], |
| options=["-M", "virt", "-cpu", "cortex-a57", "-m", "512M", "-initrd", img]) |
| self.emulator.login() |
| |
| # Check Euler identity |
| cmd = self.octave_cmd("assert (exp(i*pi)+1, 0, 1e-10)") |
| self.assertRunOk(cmd) |
| |
| # Solve equation system example from Octave homepage |
| octave_expr = "b = [4; 9; 2]; " |
| octave_expr += "A = [ 3 4 5; 1 3 1; 3 5 9 ]; " |
| octave_expr += "x = A \\ b; " |
| octave_expr += "assert(x, [-1.5; 4; -1.5], 1e-10)" |
| cmd = self.octave_cmd(octave_expr) |
| self.assertRunOk(cmd) |
| |
| # Check octave can fail |
| cmd = self.octave_cmd("assert(false)") |
| _, exit_code = self.emulator.run(cmd) |
| self.assertNotEqual(exit_code, 0) |
| |
| # Check string output |
| string = "Hello World" |
| cmd = self.octave_cmd("printf(\"{}\\n\")".format(string)) |
| output, exit_code = self.emulator.run(cmd) |
| self.assertEqual(exit_code, 0) |
| self.assertEqual(output, [string]) |
| |
| # Run some octave self tests |
| octave_modules = [ |
| "elfun/atan2d", |
| "elfun/sind", |
| "general/gradient", |
| "general/num2str", |
| "polynomial/poly", |
| "signal/fftconv", |
| "special-matrix/magic", |
| "specfun/isprime", |
| "statistics/corr", |
| "strings/str2num" |
| ] |
| |
| for mod in octave_modules: |
| cmd = self.octave_cmd('assert(test(\"{}\"),true)'.format(mod)) |
| self.assertRunOk(cmd, timeout=10) |