2023-10-12 21:38:54 +02:00
|
|
|
#include "testformatDiveGasString.h"
|
|
|
|
|
|
|
|
#include "../core/dive.h"
|
|
|
|
#include "../core/string-format.h"
|
|
|
|
|
|
|
|
void TestformatDiveGasString::init()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_empty()
|
|
|
|
{
|
|
|
|
struct dive dive = {0};
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "air");
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_air()
|
|
|
|
{
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "air");
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_nitrox() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 320;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "32%");
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_nitrox_not_use() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 320;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 1000;
|
|
|
|
cylinder->cylinder_use = NOT_USED;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "32%");
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_nitrox_deco() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 320;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 1000;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
2023-10-18 07:30:06 +02:00
|
|
|
QCOMPARE(formatDiveGasString(&dive), "32…100%");
|
2023-10-12 21:38:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_reverse_nitrox_deco() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 1000;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 270;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
2023-10-18 07:30:06 +02:00
|
|
|
QCOMPARE(formatDiveGasString(&dive), "27…100%");
|
2023-10-12 21:38:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_trimix() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 210;
|
|
|
|
cylinder->gasmix.he.permille = 350;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "21/35");
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_trimix_deco() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 210;
|
|
|
|
cylinder->gasmix.he.permille = 350;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 500;
|
|
|
|
cylinder->gasmix.he.permille = 200;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 2);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 1000;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "21/35…100%");
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_reverse_trimix_deco() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 1000;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 500;
|
|
|
|
cylinder->gasmix.he.permille = 200;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 2);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 210;
|
|
|
|
cylinder->gasmix.he.permille = 350;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "21/35…100%");
|
|
|
|
}
|
|
|
|
|
2023-10-12 21:55:16 +02:00
|
|
|
void TestformatDiveGasString::test_trimix_and_nitrox_same_o2() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 250;
|
|
|
|
cylinder->gasmix.he.permille = 0;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 250;
|
|
|
|
cylinder->gasmix.he.permille = 250;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "25/25");
|
|
|
|
}
|
|
|
|
|
|
|
|
void TestformatDiveGasString::test_trimix_and_nitrox_lower_o2() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 220;
|
|
|
|
cylinder->gasmix.he.permille = 0;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 250;
|
|
|
|
cylinder->gasmix.he.permille = 250;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "25/25");
|
|
|
|
}
|
|
|
|
|
2023-10-12 21:38:54 +02:00
|
|
|
void TestformatDiveGasString::test_ccr() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 1000;
|
|
|
|
cylinder->cylinder_use = OXYGEN;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 210;
|
|
|
|
cylinder->gasmix.he.permille = 350;
|
|
|
|
cylinder->cylinder_use = DILUENT;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "21/35");
|
|
|
|
}
|
|
|
|
|
2023-10-18 07:32:36 +02:00
|
|
|
void TestformatDiveGasString::test_ccr_bailout() {
|
|
|
|
struct dive dive = {0};
|
|
|
|
cylinder_t *cylinder = get_or_create_cylinder(&dive, 0);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 1000;
|
|
|
|
cylinder->cylinder_use = OXYGEN;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 1);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 220;
|
|
|
|
cylinder->gasmix.he.permille = 200;
|
|
|
|
cylinder->cylinder_use = DILUENT;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
cylinder = get_or_create_cylinder(&dive, 2);
|
|
|
|
|
|
|
|
cylinder->gasmix.o2.permille = 210;
|
|
|
|
cylinder->gasmix.he.permille = 0;
|
|
|
|
cylinder->start.mbar = 230000;
|
|
|
|
cylinder->end.mbar = 100000;
|
|
|
|
|
|
|
|
QCOMPARE(formatDiveGasString(&dive), "22/20");
|
|
|
|
}
|
|
|
|
|
2023-10-12 21:38:54 +02:00
|
|
|
QTEST_GUILESS_MAIN(TestformatDiveGasString)
|