#!/bin/sh

export_top_env()
{
	export suite='boot'
	export testcase='boot'
	export timeout='10m'
	export job_origin='/lkp/lkp/src/jobs/boot.yaml'
	export queue='bisect'
	export testbox='vm-ivb41-2G-3'
	export tbox_group='vm-ivb41-2G'
	export branch='userns/exit-cleanups-for-testing'
	export commit='d814d6249645f58d7399beecd9c735a71f1a1170'
	export kconfig='x86_64-allyesdebian'
	export submit_id='59375b1d0b9a93a3213fc3e3'
	export job_file='/lkp/scheduled/vm-ivb41-2G-3/boot-1-debian-x86_64-2016-08-31.cgz-d814d6249645f58d7399beecd9c735a71f1a1170-20170607-107297-y22pmt-0.yaml'
	export id='4ab77429bad0835ee68e2e3e4df3372e0dfeb76f'
	export model='qemu-system-x86_64 -enable-kvm -cpu IvyBridge'
	export nr_vm=4
	export nr_cpu=4
	export memory='2G'
	export hdd_partitions='/dev/vda /dev/vdb /dev/vdc /dev/vdd /dev/vde'
	export swap_partitions='/dev/vdf'
	export need_kconfig='CONFIG_KVM_GUEST=y'
	export ssh_base_port=23420
	export compiler='gcc-6'
	export rootfs='debian-x86_64-2016-08-31.cgz'
	export enqueue_time='2017-06-07 09:47:09 +0800'
	export _id='59375b1d0b9a93a3213fc3e3'
	export _rt='/result/boot/1/vm-ivb41-2G/debian-x86_64-2016-08-31.cgz/x86_64-allyesdebian/gcc-6/d814d6249645f58d7399beecd9c735a71f1a1170'
	export user='lkp'
	export result_root='/result/boot/1/vm-ivb41-2G/debian-x86_64-2016-08-31.cgz/x86_64-allyesdebian/gcc-6/d814d6249645f58d7399beecd9c735a71f1a1170/0'
	export LKP_SERVER='inn'
	export max_uptime=600
	export initrd='/osimage/debian/debian-x86_64-2016-08-31.cgz'
	export bootloader_append='root=/dev/ram0
user=lkp
job=/lkp/scheduled/vm-ivb41-2G-3/boot-1-debian-x86_64-2016-08-31.cgz-d814d6249645f58d7399beecd9c735a71f1a1170-20170607-107297-y22pmt-0.yaml
ARCH=x86_64
kconfig=x86_64-allyesdebian
branch=userns/exit-cleanups-for-testing
commit=d814d6249645f58d7399beecd9c735a71f1a1170
BOOT_IMAGE=/pkg/linux/x86_64-allyesdebian/gcc-6/d814d6249645f58d7399beecd9c735a71f1a1170/vmlinuz-4.12.0-rc2-00168-gd814d624
max_uptime=600
RESULT_ROOT=/result/boot/1/vm-ivb41-2G/debian-x86_64-2016-08-31.cgz/x86_64-allyesdebian/gcc-6/d814d6249645f58d7399beecd9c735a71f1a1170/0
LKP_SERVER=inn
debug
apic=debug
sysrq_always_enabled
rcupdate.rcu_cpu_stall_timeout=100
net.ifnames=0
printk.devkmsg=on
panic=-1
softlockup_panic=1
nmi_watchdog=panic
oops=panic
load_ramdisk=2
prompt_ramdisk=0
drbd.minor_count=8
systemd.log_level=err
ignore_loglevel
earlyprintk=ttyS0,115200
console=ttyS0,115200
console=tty0
vga=normal
rw'
	export lkp_initrd='/lkp/lkp/lkp-x86_64.cgz'
	export modules_initrd='/pkg/linux/x86_64-allyesdebian/gcc-6/d814d6249645f58d7399beecd9c735a71f1a1170/modules.cgz'
	export bm_initrd='/osimage/deps/debian-x86_64-2016-08-31.cgz/lkp_2017-05-01.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/rsync-rootfs_2016-11-15.cgz,/osimage/deps/debian-x86_64-2016-08-31.cgz/run-ipconfig_2016-11-15.cgz'
	export site='inn'
	export LKP_CGI_PORT=80
	export LKP_CIFS_PORT=139
	export kernel='/pkg/linux/x86_64-allyesdebian/gcc-6/d814d6249645f58d7399beecd9c735a71f1a1170/vmlinuz-4.12.0-rc2-00168-gd814d624'
	export dequeue_time='2017-06-07 09:52:16 +0800'
	export job_initrd='/lkp/scheduled/vm-ivb41-2G-3/boot-1-debian-x86_64-2016-08-31.cgz-d814d6249645f58d7399beecd9c735a71f1a1170-20170607-107297-y22pmt-0.cgz'

	[ -n "$LKP_SRC" ] ||
	export LKP_SRC=/lkp/${user:-lkp}/src
}

run_job()
{
	echo $$ > $TMP/run-job.pid

	. $LKP_SRC/lib/http.sh
	. $LKP_SRC/lib/job.sh
	. $LKP_SRC/lib/env.sh

	export_top_env

	run_monitor $LKP_SRC/monitors/one-shot/wrapper boot-slabinfo
	run_monitor $LKP_SRC/monitors/one-shot/wrapper boot-meminfo
	run_monitor $LKP_SRC/monitors/one-shot/wrapper memmap
	run_monitor $LKP_SRC/monitors/wrapper kmsg
	run_monitor $LKP_SRC/monitors/wrapper oom-killer
	run_monitor $LKP_SRC/monitors/plain/watchdog
	run_monitor $LKP_SRC/monitors/wrapper nfs-hang

	run_test $LKP_SRC/tests/wrapper sleep 1
}

extract_stats()
{
	$LKP_SRC/stats/wrapper boot-slabinfo
	$LKP_SRC/stats/wrapper boot-meminfo
	$LKP_SRC/stats/wrapper memmap
	$LKP_SRC/stats/wrapper boot-memory
	$LKP_SRC/stats/wrapper boot-time
	$LKP_SRC/stats/wrapper kernel-size
	$LKP_SRC/stats/wrapper kmsg

	$LKP_SRC/stats/wrapper time sleep.time
	$LKP_SRC/stats/wrapper time
	$LKP_SRC/stats/wrapper dmesg
	$LKP_SRC/stats/wrapper kmsg
	$LKP_SRC/stats/wrapper stderr
	$LKP_SRC/stats/wrapper last_state
}

"$@"