mirror of
https://github.com/godotengine/godot.git
synced 2025-01-24 03:24:32 -05:00
Fail instead of segfaulting in IO tests
This commit is contained in:
parent
17a8597355
commit
132e987633
2 changed files with 9 additions and 0 deletions
|
@ -39,6 +39,7 @@ namespace TestFileAccess {
|
||||||
|
|
||||||
TEST_CASE("[FileAccess] CSV read") {
|
TEST_CASE("[FileAccess] CSV read") {
|
||||||
Ref<FileAccess> f = FileAccess::open(TestUtils::get_data_path("translations.csv"), FileAccess::READ);
|
Ref<FileAccess> f = FileAccess::open(TestUtils::get_data_path("translations.csv"), FileAccess::READ);
|
||||||
|
REQUIRE(!f.is_null());
|
||||||
|
|
||||||
Vector<String> header = f->get_csv_line(); // Default delimiter: ",".
|
Vector<String> header = f->get_csv_line(); // Default delimiter: ",".
|
||||||
REQUIRE(header.size() == 3);
|
REQUIRE(header.size() == 3);
|
||||||
|
@ -81,6 +82,7 @@ TEST_CASE("[FileAccess] CSV read") {
|
||||||
|
|
||||||
TEST_CASE("[FileAccess] Get as UTF-8 String") {
|
TEST_CASE("[FileAccess] Get as UTF-8 String") {
|
||||||
Ref<FileAccess> f_lf = FileAccess::open(TestUtils::get_data_path("line_endings_lf.test.txt"), FileAccess::READ);
|
Ref<FileAccess> f_lf = FileAccess::open(TestUtils::get_data_path("line_endings_lf.test.txt"), FileAccess::READ);
|
||||||
|
REQUIRE(!f_lf.is_null());
|
||||||
String s_lf = f_lf->get_as_utf8_string();
|
String s_lf = f_lf->get_as_utf8_string();
|
||||||
f_lf->seek(0);
|
f_lf->seek(0);
|
||||||
String s_lf_nocr = f_lf->get_as_utf8_string(true);
|
String s_lf_nocr = f_lf->get_as_utf8_string(true);
|
||||||
|
@ -88,6 +90,7 @@ TEST_CASE("[FileAccess] Get as UTF-8 String") {
|
||||||
CHECK(s_lf_nocr == "Hello darkness\nMy old friend\nI've come to talk\nWith you again\n");
|
CHECK(s_lf_nocr == "Hello darkness\nMy old friend\nI've come to talk\nWith you again\n");
|
||||||
|
|
||||||
Ref<FileAccess> f_crlf = FileAccess::open(TestUtils::get_data_path("line_endings_crlf.test.txt"), FileAccess::READ);
|
Ref<FileAccess> f_crlf = FileAccess::open(TestUtils::get_data_path("line_endings_crlf.test.txt"), FileAccess::READ);
|
||||||
|
REQUIRE(!f_crlf.is_null());
|
||||||
String s_crlf = f_crlf->get_as_utf8_string();
|
String s_crlf = f_crlf->get_as_utf8_string();
|
||||||
f_crlf->seek(0);
|
f_crlf->seek(0);
|
||||||
String s_crlf_nocr = f_crlf->get_as_utf8_string(true);
|
String s_crlf_nocr = f_crlf->get_as_utf8_string(true);
|
||||||
|
@ -95,6 +98,7 @@ TEST_CASE("[FileAccess] Get as UTF-8 String") {
|
||||||
CHECK(s_crlf_nocr == "Hello darkness\nMy old friend\nI've come to talk\nWith you again\n");
|
CHECK(s_crlf_nocr == "Hello darkness\nMy old friend\nI've come to talk\nWith you again\n");
|
||||||
|
|
||||||
Ref<FileAccess> f_cr = FileAccess::open(TestUtils::get_data_path("line_endings_cr.test.txt"), FileAccess::READ);
|
Ref<FileAccess> f_cr = FileAccess::open(TestUtils::get_data_path("line_endings_cr.test.txt"), FileAccess::READ);
|
||||||
|
REQUIRE(!f_cr.is_null());
|
||||||
String s_cr = f_cr->get_as_utf8_string();
|
String s_cr = f_cr->get_as_utf8_string();
|
||||||
f_cr->seek(0);
|
f_cr->seek(0);
|
||||||
String s_cr_nocr = f_cr->get_as_utf8_string(true);
|
String s_cr_nocr = f_cr->get_as_utf8_string(true);
|
||||||
|
|
|
@ -107,6 +107,7 @@ TEST_CASE("[Image] Saving and loading") {
|
||||||
// Load BMP
|
// Load BMP
|
||||||
Ref<Image> image_bmp = memnew(Image());
|
Ref<Image> image_bmp = memnew(Image());
|
||||||
Ref<FileAccess> f_bmp = FileAccess::open(TestUtils::get_data_path("images/icon.bmp"), FileAccess::READ, &err);
|
Ref<FileAccess> f_bmp = FileAccess::open(TestUtils::get_data_path("images/icon.bmp"), FileAccess::READ, &err);
|
||||||
|
REQUIRE(!f_bmp.is_null());
|
||||||
PackedByteArray data_bmp;
|
PackedByteArray data_bmp;
|
||||||
data_bmp.resize(f_bmp->get_length() + 1);
|
data_bmp.resize(f_bmp->get_length() + 1);
|
||||||
f_bmp->get_buffer(data_bmp.ptrw(), f_bmp->get_length());
|
f_bmp->get_buffer(data_bmp.ptrw(), f_bmp->get_length());
|
||||||
|
@ -117,6 +118,7 @@ TEST_CASE("[Image] Saving and loading") {
|
||||||
// Load JPG
|
// Load JPG
|
||||||
Ref<Image> image_jpg = memnew(Image());
|
Ref<Image> image_jpg = memnew(Image());
|
||||||
Ref<FileAccess> f_jpg = FileAccess::open(TestUtils::get_data_path("images/icon.jpg"), FileAccess::READ, &err);
|
Ref<FileAccess> f_jpg = FileAccess::open(TestUtils::get_data_path("images/icon.jpg"), FileAccess::READ, &err);
|
||||||
|
REQUIRE(!f_jpg.is_null());
|
||||||
PackedByteArray data_jpg;
|
PackedByteArray data_jpg;
|
||||||
data_jpg.resize(f_jpg->get_length() + 1);
|
data_jpg.resize(f_jpg->get_length() + 1);
|
||||||
f_jpg->get_buffer(data_jpg.ptrw(), f_jpg->get_length());
|
f_jpg->get_buffer(data_jpg.ptrw(), f_jpg->get_length());
|
||||||
|
@ -127,6 +129,7 @@ TEST_CASE("[Image] Saving and loading") {
|
||||||
// Load WebP
|
// Load WebP
|
||||||
Ref<Image> image_webp = memnew(Image());
|
Ref<Image> image_webp = memnew(Image());
|
||||||
Ref<FileAccess> f_webp = FileAccess::open(TestUtils::get_data_path("images/icon.webp"), FileAccess::READ, &err);
|
Ref<FileAccess> f_webp = FileAccess::open(TestUtils::get_data_path("images/icon.webp"), FileAccess::READ, &err);
|
||||||
|
REQUIRE(!f_webp.is_null());
|
||||||
PackedByteArray data_webp;
|
PackedByteArray data_webp;
|
||||||
data_webp.resize(f_webp->get_length() + 1);
|
data_webp.resize(f_webp->get_length() + 1);
|
||||||
f_webp->get_buffer(data_webp.ptrw(), f_webp->get_length());
|
f_webp->get_buffer(data_webp.ptrw(), f_webp->get_length());
|
||||||
|
@ -137,6 +140,7 @@ TEST_CASE("[Image] Saving and loading") {
|
||||||
// Load PNG
|
// Load PNG
|
||||||
Ref<Image> image_png = memnew(Image());
|
Ref<Image> image_png = memnew(Image());
|
||||||
Ref<FileAccess> f_png = FileAccess::open(TestUtils::get_data_path("images/icon.png"), FileAccess::READ, &err);
|
Ref<FileAccess> f_png = FileAccess::open(TestUtils::get_data_path("images/icon.png"), FileAccess::READ, &err);
|
||||||
|
REQUIRE(!f_png.is_null());
|
||||||
PackedByteArray data_png;
|
PackedByteArray data_png;
|
||||||
data_png.resize(f_png->get_length() + 1);
|
data_png.resize(f_png->get_length() + 1);
|
||||||
f_png->get_buffer(data_png.ptrw(), f_png->get_length());
|
f_png->get_buffer(data_png.ptrw(), f_png->get_length());
|
||||||
|
@ -147,6 +151,7 @@ TEST_CASE("[Image] Saving and loading") {
|
||||||
// Load TGA
|
// Load TGA
|
||||||
Ref<Image> image_tga = memnew(Image());
|
Ref<Image> image_tga = memnew(Image());
|
||||||
Ref<FileAccess> f_tga = FileAccess::open(TestUtils::get_data_path("images/icon.tga"), FileAccess::READ, &err);
|
Ref<FileAccess> f_tga = FileAccess::open(TestUtils::get_data_path("images/icon.tga"), FileAccess::READ, &err);
|
||||||
|
REQUIRE(!f_tga.is_null());
|
||||||
PackedByteArray data_tga;
|
PackedByteArray data_tga;
|
||||||
data_tga.resize(f_tga->get_length() + 1);
|
data_tga.resize(f_tga->get_length() + 1);
|
||||||
f_tga->get_buffer(data_tga.ptrw(), f_tga->get_length());
|
f_tga->get_buffer(data_tga.ptrw(), f_tga->get_length());
|
||||||
|
|
Loading…
Add table
Reference in a new issue