#!../../../common/bats/bin/bats
# -*-sh-*-

source ../../../common/test_helper_functions.bash || exit 1
source ../../../common/functions || exit 1

if [ -s ../../../TEST_ENV ]; then
	source ../../../TEST_ENV
fi

check_rms

NODES=2
TASKS=$(tasks_count 4)
ARGS=null

@test "[libs/Trilinos] Kokkos-MemorySpace runs under resource manager (${RESOURCE_MANAGER}/${LMOD_FAMILY_COMPILER}/${LMOD_FAMILY_MPI})" {
	EXE=./lesson_kokkos_memspace
	if [ ! -s "${EXE}" ]; then
		flunk "${EXE} binary does not exist"
	fi

	run_mpi_binary -t 5 "${EXE}" "${ARGS}" "${NODES}" "${TASKS}"
	assert_success
}

@test "[libs/Trilinos] Tpetra-InitMPI runs under resource manager (${RESOURCE_MANAGER}/${LMOD_FAMILY_COMPILER}/${LMOD_FAMILY_MPI})" {
	EXE=./lesson_tpetra_init
	if [ ! -s "${EXE}" ]; then
		flunk "${EXE} binary does not exist"
	fi

	run_mpi_binary -t 5 "${EXE}" "${ARGS}" "${NODES}" "${TASKS}"
	assert_success
}

@test "[libs/Trilinos] Tpetra-DataRedistribution runs under resource manager (${RESOURCE_MANAGER}/${LMOD_FAMILY_COMPILER}/${LMOD_FAMILY_MPI})" {
	EXE=./lesson_tpetra_dataredist
	if [ ! -s "${EXE}" ]; then
		flunk "${EXE} binary does not exist"
	fi

	run_mpi_binary -t 5 "${EXE}" "${ARGS}" "${NODES}" "${TASKS}"
	assert_success
}

@test "[libs/Trilinos] Teuchos-ParameterList runs under resource manager (${RESOURCE_MANAGER}/${LMOD_FAMILY_COMPILER}/${LMOD_FAMILY_MPI})" {
	EXE=./lesson_teuchos_pl
	if [ ! -s "${EXE}" ]; then
		flunk "${EXE} binary does not exist"
	fi

	run_mpi_binary -t 5 "${EXE}" "${ARGS}" "${NODES}" "${TASKS}"
	assert_success
}

@test "[libs/Trilinos] Teuchos-LAPACK runs under resource manager (${RESOURCE_MANAGER}/${LMOD_FAMILY_COMPILER}/${LMOD_FAMILY_MPI})" {
	EXE=./lesson_teuchos_lapack
	if [ ! -s "${EXE}" ]; then
		flunk "${EXE} binary does not exist"
	fi

	run_mpi_binary -t 5 "${EXE}" "${ARGS}" "${NODES}" "${TASKS}"
	assert_success
}

@test "[libs/Trilinos] Teuchos-BLAS runs under resource manager (${RESOURCE_MANAGER}/${LMOD_FAMILY_COMPILER}/${LMOD_FAMILY_MPI})" {
	EXE=./lesson_teuchos_blas
	if [ ! -s "${EXE}" ]; then
		flunk "${EXE} binary does not exist"
	fi

	run_mpi_binary -t 5 "${EXE}" "${ARGS}" "${NODES}" "${TASKS}"
	assert_success
}
