mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-12-12 04:34:43 +04:00
* toolbox, gui: fixes for compressed icon handling * ufbt: fixes for generated vscode project * scripts: increased max dimensions for image converter * icon type changes * linter fixes; api sync * gui: docs fix * toolbox: fixed potential decoder buffer overflow * minor cleanup * fbt: sdk: suppressed deprecation warnings in API table * toolbox: compress: added unit tests vscode: now installs resources for unit_tests unit_tests: now loads subghz region data * toolbox: compress: review fixes, pt 1 * compress: now passes decoder buffer size as constructor argument; auto-resize decoder buffer; crash on failed icon decompression * PVS fixes * pvs fixes, pt2 * doxygen fixes * investigating unit test failures * investigating unit test failures * investigating unit test failures * investigating unit test failures * investigating unit test failures * UnitTests: move all tests into plugins, brakes testing * UnitTests: add plugin API and update plugin entrypoints * UniTests: Test runner that works with plugins * fbt: extra filtering for extapps to include in build * UnitTests: filter tests by name * loader: restored API table for unit_test build config * Add various missing symbols to API table * UnitTest: fail on plugin load error * UnitTests: cleanup plugin api and reporting * unit_tests: composite resolver * UnitTests: remove unused declaration * unit_tests, nfc: moved mock nfc implementation to libnfc * unit_tests: api: removed redundant #define * toolbox: compress: removed size_hint for icons; triggering furi_check on oversized icons * gui: icon, icon_animation: removed size hit APIs * Format Sources. Cleanup code. * loader: refuse to start .fal as app * toolbox: compress: fixed memory corruption in operations with small destination buffer; added unit tests for that case * unit_tests: proper test skipping; better selective test interface * unit_tests: moved 'loading' logging to proper location Co-authored-by: あく <alleteam@gmail.com>
72 lines
3.0 KiB
C
72 lines
3.0 KiB
C
#include <furi.h>
|
|
#include <furi_hal.h>
|
|
#include "../test.h"
|
|
|
|
static void power_test_deinit(void) {
|
|
// Try to reset to default charge voltage limit
|
|
furi_hal_power_set_battery_charge_voltage_limit(4.208f);
|
|
}
|
|
|
|
MU_TEST(test_power_charge_voltage_limit_exact) {
|
|
// Power of 16mV charge voltage limits get applied exactly
|
|
// (bq25896 charge controller works in 16mV increments)
|
|
//
|
|
// This test may need adapted if other charge controllers are used in the future.
|
|
for(uint16_t charge_mv = 3840; charge_mv <= 4208; charge_mv += 16) {
|
|
float charge_volt = (float)charge_mv / 1000.0f;
|
|
furi_hal_power_set_battery_charge_voltage_limit(charge_volt);
|
|
mu_assert_double_eq(charge_volt, furi_hal_power_get_battery_charge_voltage_limit());
|
|
}
|
|
}
|
|
|
|
MU_TEST(test_power_charge_voltage_limit_floating_imprecision) {
|
|
// 4.016f should act as 4.016 V, even with floating point imprecision
|
|
furi_hal_power_set_battery_charge_voltage_limit(4.016f);
|
|
mu_assert_double_eq(4.016f, furi_hal_power_get_battery_charge_voltage_limit());
|
|
}
|
|
|
|
MU_TEST(test_power_charge_voltage_limit_inexact) {
|
|
// Charge voltage limits that are not power of 16mV get truncated down
|
|
furi_hal_power_set_battery_charge_voltage_limit(3.841f);
|
|
mu_assert_double_eq(3.840, furi_hal_power_get_battery_charge_voltage_limit());
|
|
|
|
furi_hal_power_set_battery_charge_voltage_limit(3.900f);
|
|
mu_assert_double_eq(3.888, furi_hal_power_get_battery_charge_voltage_limit());
|
|
|
|
furi_hal_power_set_battery_charge_voltage_limit(4.200f);
|
|
mu_assert_double_eq(4.192, furi_hal_power_get_battery_charge_voltage_limit());
|
|
}
|
|
|
|
MU_TEST(test_power_charge_voltage_limit_invalid_clamped) {
|
|
// Out-of-range charge voltage limits get clamped to 3.840 V and 4.208 V
|
|
furi_hal_power_set_battery_charge_voltage_limit(3.808f);
|
|
mu_assert_double_eq(3.840, furi_hal_power_get_battery_charge_voltage_limit());
|
|
furi_hal_power_set_battery_charge_voltage_limit(1.0f);
|
|
mu_assert_double_eq(3.840, furi_hal_power_get_battery_charge_voltage_limit());
|
|
|
|
// NOTE: Intentionally picking a small increment above 4.208 V to reduce the risk of an
|
|
// unhappy battery if this fails.
|
|
furi_hal_power_set_battery_charge_voltage_limit(4.240f);
|
|
mu_assert_double_eq(4.208, furi_hal_power_get_battery_charge_voltage_limit());
|
|
// Likewise, picking a number that the uint8_t wraparound in the driver would result in a
|
|
// VREG value under 23 if this test fails.
|
|
// E.g. (uint8_t)((8105-3840)/16) -> 10
|
|
furi_hal_power_set_battery_charge_voltage_limit(8.105f);
|
|
mu_assert_double_eq(4.208, furi_hal_power_get_battery_charge_voltage_limit());
|
|
}
|
|
|
|
MU_TEST_SUITE(test_power_suite) {
|
|
MU_RUN_TEST(test_power_charge_voltage_limit_exact);
|
|
MU_RUN_TEST(test_power_charge_voltage_limit_floating_imprecision);
|
|
MU_RUN_TEST(test_power_charge_voltage_limit_inexact);
|
|
MU_RUN_TEST(test_power_charge_voltage_limit_invalid_clamped);
|
|
power_test_deinit();
|
|
}
|
|
|
|
int run_minunit_test_power(void) {
|
|
MU_RUN_SUITE(test_power_suite);
|
|
return MU_EXIT_CODE;
|
|
}
|
|
|
|
TEST_API_DEFINE(run_minunit_test_power)
|