1
0
mirror of https://review.coreboot.org/flashrom.git synced 2025-04-28 15:33:42 +02:00

tests: Add basic lifecycle test for mediatek_i2c_spi

This unit test does not require any additional mocks because init
and shutdown of i2c infra was covered in realtek programmer lifecycle.
Default mocking of i2c is sufficient to run a basic lifecycle.

To run the test, config option for the programmer needs to be
enabled explicitly, since by default this programmer is disabled.

BUG=b:238816884
TEST=meson configure -Dconfig_mediatek_i2c_spi=true
ninja test

Change-Id: I98a12067d165c90013d33ffc45d20dab5c364c83
Signed-off-by: Anastasia Klimchuk <aklm@chromium.org>
Reviewed-on: https://review.coreboot.org/c/flashrom/+/66261
Reviewed-by: Edward O'Callaghan <quasisec@chromium.org>
Reviewed-by: Felix Singer <felixsinger@posteo.net>
Reviewed-by: Thomas Heijligen <src@posteo.de>
Reviewed-by: Alexander Goncharov <chat@joursoir.net>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
Anastasia Klimchuk 2022-07-29 16:16:25 +10:00
parent 47541722c1
commit 5c5b0a8fab
4 changed files with 39 additions and 0 deletions

36
tests/mediatek_i2c_spi.c Normal file
View File

@ -0,0 +1,36 @@
/*
* This file is part of the flashrom project.
*
* Copyright 2022 Google LLC
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#include "lifecycle.h"
#if CONFIG_MEDIATEK_I2C_SPI == 1
void mediatek_i2c_spi_basic_lifecycle_test_success(void **state)
{
struct io_mock_fallback_open_state mediatek_i2c_spi_fallback_open_state = {
.noc = 0,
.paths = { "/dev/i2c-254", NULL },
.flags = { O_RDWR },
};
const struct io_mock mediatek_i2c_spi_io = {
.fallback_open_state = &mediatek_i2c_spi_fallback_open_state,
};
run_basic_lifecycle(state, &mediatek_i2c_spi_io, &programmer_mediatek_i2c_spi, "bus=254,allow_brick=yes");
}
#else
SKIP_TEST(mediatek_i2c_spi_basic_lifecycle_test_success)
#endif /* CONFIG_MEDIATEK_I2C_SPI */

View File

@ -26,6 +26,7 @@ srcs = [
'linux_mtd.c', 'linux_mtd.c',
'linux_spi.c', 'linux_spi.c',
'parade_lspcon.c', 'parade_lspcon.c',
'mediatek_i2c_spi.c',
'realtek_mst_i2c_spi.c', 'realtek_mst_i2c_spi.c',
'layout.c', 'layout.c',
'chip.c', 'chip.c',

View File

@ -416,6 +416,7 @@ int main(int argc, char *argv[])
cmocka_unit_test(linux_mtd_probe_lifecycle_test_success), cmocka_unit_test(linux_mtd_probe_lifecycle_test_success),
cmocka_unit_test(linux_spi_probe_lifecycle_test_success), cmocka_unit_test(linux_spi_probe_lifecycle_test_success),
cmocka_unit_test(parade_lspcon_basic_lifecycle_test_success), cmocka_unit_test(parade_lspcon_basic_lifecycle_test_success),
cmocka_unit_test(mediatek_i2c_spi_basic_lifecycle_test_success),
cmocka_unit_test(realtek_mst_basic_lifecycle_test_success), cmocka_unit_test(realtek_mst_basic_lifecycle_test_success),
}; };
ret |= cmocka_run_group_tests_name("lifecycle.c tests", lifecycle_tests, NULL, NULL); ret |= cmocka_run_group_tests_name("lifecycle.c tests", lifecycle_tests, NULL, NULL);

View File

@ -51,6 +51,7 @@ void dediprog_basic_lifecycle_test_success(void **state);
void linux_mtd_probe_lifecycle_test_success(void **state); void linux_mtd_probe_lifecycle_test_success(void **state);
void linux_spi_probe_lifecycle_test_success(void **state); void linux_spi_probe_lifecycle_test_success(void **state);
void parade_lspcon_basic_lifecycle_test_success(void **state); void parade_lspcon_basic_lifecycle_test_success(void **state);
void mediatek_i2c_spi_basic_lifecycle_test_success(void **state);
void realtek_mst_basic_lifecycle_test_success(void **state); void realtek_mst_basic_lifecycle_test_success(void **state);
/* layout.c */ /* layout.c */