2017-09-07 19:50:35 +00:00
|
|
|
/*
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
Open Asset Import Library (assimp)
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
|
2019-01-30 08:41:39 +00:00
|
|
|
Copyright (c) 2006-2019, assimp team
|
2018-01-28 18:42:05 +00:00
|
|
|
|
2017-09-07 19:50:35 +00:00
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use of this software in source and binary forms,
|
|
|
|
with or without modification, are permitted provided that the following
|
|
|
|
conditions are met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above
|
|
|
|
copyright notice, this list of conditions and the
|
|
|
|
following disclaimer.
|
|
|
|
|
|
|
|
* Redistributions in binary form must reproduce the above
|
|
|
|
copyright notice, this list of conditions and the
|
|
|
|
following disclaimer in the documentation and/or other
|
|
|
|
materials provided with the distribution.
|
|
|
|
|
|
|
|
* Neither the name of the assimp team, nor the names of its
|
|
|
|
contributors may be used to endorse or promote products
|
|
|
|
derived from this software without specific prior
|
|
|
|
written permission of the assimp team.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
#include "UnitTestPCH.h"
|
|
|
|
#include "AbstractImportExportBase.h"
|
|
|
|
|
|
|
|
#include <assimp/Importer.hpp>
|
2017-09-12 13:57:58 +00:00
|
|
|
#include <assimp/Exporter.hpp>
|
2017-11-21 16:04:22 +00:00
|
|
|
#include <assimp/postprocess.h>
|
2018-05-25 00:25:26 +00:00
|
|
|
#include <assimp/scene.h>
|
2019-12-05 14:05:49 +00:00
|
|
|
#include <assimp/commonMetaData.h>
|
|
|
|
|
2018-08-01 21:27:04 +00:00
|
|
|
#include <array>
|
2017-09-07 19:50:35 +00:00
|
|
|
|
2019-12-12 12:06:36 +00:00
|
|
|
#include <assimp/pbrmaterial.h>
|
|
|
|
|
2017-09-07 19:50:35 +00:00
|
|
|
using namespace Assimp;
|
|
|
|
|
|
|
|
class utglTF2ImportExport : public AbstractImportExportBase {
|
|
|
|
public:
|
|
|
|
virtual bool importerTest() {
|
|
|
|
Assimp::Importer importer;
|
2019-07-19 08:38:44 +00:00
|
|
|
const aiScene *scene = importer.ReadFile( ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF/BoxTextured.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
2018-05-25 00:25:26 +00:00
|
|
|
EXPECT_NE( scene, nullptr );
|
2019-07-19 08:38:44 +00:00
|
|
|
if (!scene) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-05-25 00:25:26 +00:00
|
|
|
|
|
|
|
EXPECT_TRUE( scene->HasMaterials() );
|
2019-07-19 08:38:44 +00:00
|
|
|
if (!scene->HasMaterials()) {
|
|
|
|
return false;
|
|
|
|
}
|
2018-05-25 00:25:26 +00:00
|
|
|
const aiMaterial *material = scene->mMaterials[0];
|
|
|
|
|
|
|
|
aiString path;
|
|
|
|
aiTextureMapMode modes[2];
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ( aiReturn_SUCCESS, material->GetTexture(aiTextureType_DIFFUSE, 0, &path, nullptr, nullptr,
|
|
|
|
nullptr, nullptr, modes) );
|
2018-05-25 00:25:26 +00:00
|
|
|
EXPECT_STREQ( path.C_Str(), "CesiumLogoFlat.png" );
|
|
|
|
EXPECT_EQ( modes[0], aiTextureMapMode_Mirror );
|
|
|
|
EXPECT_EQ( modes[1], aiTextureMapMode_Clamp );
|
|
|
|
|
|
|
|
return true;
|
2017-09-07 19:50:35 +00:00
|
|
|
}
|
2017-09-12 13:57:58 +00:00
|
|
|
|
2017-11-29 17:15:15 +00:00
|
|
|
virtual bool binaryImporterTest() {
|
|
|
|
Assimp::Importer importer;
|
2019-07-19 08:38:44 +00:00
|
|
|
const aiScene *scene = importer.ReadFile( ASSIMP_TEST_MODELS_DIR "/glTF2/2CylinderEngine-glTF-Binary/2CylinderEngine.glb",
|
|
|
|
aiProcess_ValidateDataStructure);
|
2017-11-29 17:15:15 +00:00
|
|
|
return nullptr != scene;
|
|
|
|
}
|
|
|
|
|
2017-09-12 13:57:58 +00:00
|
|
|
#ifndef ASSIMP_BUILD_NO_EXPORT
|
|
|
|
virtual bool exporterTest() {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
Assimp::Exporter exporter;
|
2019-07-19 08:38:44 +00:00
|
|
|
const aiScene *scene = importer.ReadFile( ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF/BoxTextured.gltf",
|
|
|
|
aiProcess_ValidateDataStructure );
|
2017-09-12 13:57:58 +00:00
|
|
|
EXPECT_NE( nullptr, scene );
|
|
|
|
EXPECT_EQ( aiReturn_SUCCESS, exporter.Export( scene, "gltf2", ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF/BoxTextured_out.gltf" ) );
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
#endif // ASSIMP_BUILD_NO_EXPORT
|
|
|
|
|
2017-09-07 19:50:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F( utglTF2ImportExport, importglTF2FromFileTest ) {
|
|
|
|
EXPECT_TRUE( importerTest() );
|
|
|
|
}
|
2017-09-12 13:57:58 +00:00
|
|
|
|
2017-11-29 17:15:15 +00:00
|
|
|
TEST_F( utglTF2ImportExport, importBinaryglTF2FromFileTest ) {
|
|
|
|
EXPECT_TRUE( binaryImporterTest() );
|
|
|
|
}
|
|
|
|
|
2018-09-21 18:04:53 +00:00
|
|
|
#ifndef ASSIMP_BUILD_NO_EXPORT
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2AndExportToOBJ) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
Assimp::Exporter exporter;
|
2019-07-19 08:38:44 +00:00
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF/BoxTextured.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
2018-09-21 18:04:53 +00:00
|
|
|
EXPECT_NE(nullptr, scene);
|
|
|
|
EXPECT_EQ(aiReturn_SUCCESS, exporter.Export(scene, "obj", ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF/BoxTextured_out.obj"));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2EmbeddedAndExportToOBJ) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
Assimp::Exporter exporter;
|
2019-07-19 08:38:44 +00:00
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF-Embedded/BoxTextured.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
2018-09-21 18:04:53 +00:00
|
|
|
EXPECT_NE(nullptr, scene);
|
|
|
|
EXPECT_EQ(aiReturn_SUCCESS, exporter.Export(scene, "obj", ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF-Embedded/BoxTextured_out.obj"));
|
|
|
|
}
|
|
|
|
#endif // ASSIMP_BUILD_NO_EXPORT
|
|
|
|
|
2018-08-04 10:20:56 +00:00
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModePointsWithoutIndices) {
|
2018-08-01 21:27:04 +00:00
|
|
|
Assimp::Importer importer;
|
2018-08-04 10:20:56 +00:00
|
|
|
//Points without indices
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_00.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 1024u);
|
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i) {
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mNumIndices, 1u);
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeLinesWithoutIndices) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Lines without indices
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_01.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 8u);
|
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i) {
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mNumIndices, 2u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], i*2u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[1], i*2u + 1u);
|
2018-08-04 10:20:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeLinesLoopWithoutIndices) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Lines loop without indices
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_02.gltf", aiProcess_ValidateDataStructure);
|
2018-08-01 21:27:04 +00:00
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
2018-08-04 10:20:56 +00:00
|
|
|
|
2019-07-19 09:26:48 +00:00
|
|
|
std::array<unsigned int, 5> l1 = {{ 0u, 1u, 2u, 3u, 0u }};
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 2u);
|
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i) {
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mNumIndices, 2u);
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], l1[i]);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[1], l1[i + 1u]);
|
2018-08-04 10:20:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeLinesStripWithoutIndices) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Lines strip without indices
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_03.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 5u);
|
2018-08-04 10:20:56 +00:00
|
|
|
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 2u);
|
2019-07-19 08:38:44 +00:00
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i) {
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mNumIndices, 2u);
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], i);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[1], i + 1u);
|
2018-08-04 10:20:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeTrianglesStripWithoutIndices) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Triangles strip without indices
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_04.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumFaces, 2u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
2019-07-19 09:26:48 +00:00
|
|
|
std::array<unsigned int, 3> f1 = {{ 0u, 1u, 2u }};
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 3u);
|
|
|
|
for (unsigned int i = 0; i < 3; ++i) {
|
2018-08-01 21:27:04 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mIndices[i], f1[i]);
|
|
|
|
}
|
|
|
|
|
2019-07-19 08:38:44 +00:00
|
|
|
std::array<unsigned int, 3> f2 = {{ 2u, 1u, 3u }};
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mNumIndices, 3u);
|
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-01 21:27:04 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mIndices[i], f2[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-04 10:20:56 +00:00
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeTrianglesFanWithoutIndices) {
|
2018-08-01 21:27:04 +00:00
|
|
|
Assimp::Importer importer;
|
2018-08-04 10:20:56 +00:00
|
|
|
//Triangles fan without indices
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_05.gltf", aiProcess_ValidateDataStructure);
|
2018-08-01 21:27:04 +00:00
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumFaces, 2u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
2019-07-19 09:55:12 +00:00
|
|
|
std::array<unsigned int, 3> f1 = {{ 0u, 1u, 2u }};
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 3u);
|
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-01 21:27:04 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mIndices[i], f1[i]);
|
|
|
|
}
|
|
|
|
|
2019-07-19 09:26:48 +00:00
|
|
|
std::array<unsigned int, 3> f2 = {{ 0u, 2u, 3u }};
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mNumIndices, 3u);
|
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mIndices[i], f2[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeTrianglesWithoutIndices) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Triangles without indices
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_06.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumFaces, 2u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 6u);
|
|
|
|
std::array<unsigned int, 3> f1 = {{ 0u, 1u, 2u }};
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 3u);
|
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mIndices[i], f1[i]);
|
|
|
|
}
|
|
|
|
|
2019-07-19 08:38:44 +00:00
|
|
|
std::array<unsigned int, 3> f2 = {{ 3u, 4u, 5u }};
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mNumIndices, 3u);
|
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-01 21:27:04 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mIndices[i], f2[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-02 17:07:51 +00:00
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModePoints) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Line loop
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_07.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 1024u);
|
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i) {
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mNumIndices, 1u);
|
2018-08-02 17:07:51 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-04 10:20:56 +00:00
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeLines) {
|
2018-08-02 17:05:45 +00:00
|
|
|
Assimp::Importer importer;
|
2018-08-04 10:20:56 +00:00
|
|
|
//Lines
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_08.gltf", aiProcess_ValidateDataStructure);
|
2018-08-02 17:05:45 +00:00
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
|
|
|
std::array<unsigned int, 5> l1 = {{ 0u, 3u, 2u, 1u, 0u }};
|
2019-07-19 08:38:44 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 2u);
|
2018-08-02 17:07:51 +00:00
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i)
|
2018-08-02 17:05:45 +00:00
|
|
|
{
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], l1[i]);
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[1], l1[i + 1]);
|
2018-08-02 17:05:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-04 10:20:56 +00:00
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeLineLoop) {
|
2018-08-02 17:05:45 +00:00
|
|
|
Assimp::Importer importer;
|
2018-08-04 10:20:56 +00:00
|
|
|
//Line loop
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_09.gltf", aiProcess_ValidateDataStructure);
|
2018-08-02 17:05:45 +00:00
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
2019-07-19 11:03:08 +00:00
|
|
|
std::array<unsigned int, 5> l1 = {{ 0, 3u, 2u, 1u, 0u }};
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 2u);
|
2018-08-02 17:07:51 +00:00
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i)
|
2018-08-02 17:05:45 +00:00
|
|
|
{
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], l1[i]);
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[1], l1[i+1]);
|
2018-08-02 17:05:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeLineStrip) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Lines Strip
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_10.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
2019-07-19 11:03:08 +00:00
|
|
|
std::array<unsigned int, 5> l1 = {{ 0u, 3u, 2u, 1u, 0u }};
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 2u);
|
|
|
|
for (unsigned int i = 0; i < scene->mMeshes[0]->mNumFaces; ++i) {
|
2018-08-02 17:05:45 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[0], l1[i]);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[i].mIndices[1], l1[i + 1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-04 10:20:56 +00:00
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeTrianglesStrip) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Triangles strip
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_11.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumFaces, 2u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
2019-07-19 11:03:08 +00:00
|
|
|
std::array<unsigned int, 3> f1 = {{ 0u, 3u, 1u }};
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 3u);
|
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mIndices[i], f1[i]);
|
|
|
|
}
|
|
|
|
|
2019-07-19 11:03:08 +00:00
|
|
|
std::array<unsigned int, 3> f2 = {{ 1u, 3u, 2u }};
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mNumIndices, 3u);
|
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mIndices[i], f2[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2PrimitiveModeTrianglesFan) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
//Triangles fan
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Asset-Generator/Mesh_PrimitiveMode/Mesh_PrimitiveMode_12.gltf", aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
2019-07-19 09:26:48 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 4u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumFaces, 2u);
|
2019-07-19 11:03:08 +00:00
|
|
|
std::array<unsigned int, 3> f1 = {{ 0u, 3u, 2u }};
|
2019-07-19 11:28:00 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mNumIndices, 3u );
|
2019-07-19 08:38:44 +00:00
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[0].mIndices[i], f1[i]);
|
|
|
|
}
|
|
|
|
|
2019-07-19 09:26:48 +00:00
|
|
|
std::array<unsigned int, 3> f2 = {{ 0u, 2u, 1u }};
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mNumIndices, 3u );
|
2019-07-19 08:38:44 +00:00
|
|
|
for (size_t i = 0; i < 3; ++i) {
|
2018-08-04 10:20:56 +00:00
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mFaces[1].mIndices[i], f2[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-08 18:40:01 +00:00
|
|
|
std::vector<char> ReadFile(const char* name) {
|
2018-10-07 17:22:13 +00:00
|
|
|
std::vector<char> ret;
|
|
|
|
|
|
|
|
FILE* p = ::fopen(name, "r");
|
2018-10-08 18:40:01 +00:00
|
|
|
if (nullptr == p) {
|
|
|
|
return ret;
|
2018-10-07 17:22:13 +00:00
|
|
|
}
|
2018-10-08 18:40:01 +00:00
|
|
|
|
|
|
|
::fseek(p, 0, SEEK_END);
|
2018-12-28 00:44:56 +00:00
|
|
|
const size_t size = ::ftell(p);
|
2018-10-08 18:40:01 +00:00
|
|
|
::fseek(p, 0, SEEK_SET);
|
|
|
|
|
|
|
|
ret.resize(size);
|
2018-12-28 00:44:56 +00:00
|
|
|
const size_t readSize = ::fread(&ret[0], 1, size, p);
|
|
|
|
EXPECT_EQ(readSize, size);
|
2018-10-08 18:40:01 +00:00
|
|
|
::fclose(p);
|
|
|
|
|
2018-10-07 17:22:13 +00:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(utglTF2ImportExport, importglTF2FromMemory) {
|
2018-10-09 14:27:48 +00:00
|
|
|
/*const auto flags = aiProcess_CalcTangentSpace | aiProcess_Triangulate | aiProcess_RemoveComponent |
|
2018-10-07 17:22:13 +00:00
|
|
|
aiProcess_GenSmoothNormals | aiProcess_PreTransformVertices | aiProcess_FixInfacingNormals |
|
|
|
|
aiProcess_FindDegenerates | aiProcess_GenUVCoords | aiProcess_SortByPType;
|
2018-10-09 14:27:48 +00:00
|
|
|
const auto& buff = ReadFile("C:\\Users\\kimkulling\\Downloads\\camel\\camel\\scene.gltf");*/
|
2018-10-09 09:55:37 +00:00
|
|
|
/*const aiScene* Scene = ::aiImportFileFromMemory(&buff[0], buff.size(), flags, ".gltf");
|
|
|
|
EXPECT_EQ( nullptr, Scene );*/
|
2018-10-07 17:22:13 +00:00
|
|
|
}
|
|
|
|
|
2019-02-25 21:06:24 +00:00
|
|
|
TEST_F( utglTF2ImportExport, bug_import_simple_skin ) {
|
|
|
|
Assimp::Importer importer;
|
2019-07-19 09:26:48 +00:00
|
|
|
const aiScene *scene = importer.ReadFile( ASSIMP_TEST_MODELS_DIR "/glTF2/simple_skin/simple_skin.gltf",
|
|
|
|
aiProcess_ValidateDataStructure );
|
2019-02-25 22:19:21 +00:00
|
|
|
EXPECT_NE( nullptr, scene );
|
2019-02-25 21:06:24 +00:00
|
|
|
}
|
2019-02-25 22:19:21 +00:00
|
|
|
|
2019-09-11 20:34:53 +00:00
|
|
|
TEST_F(utglTF2ImportExport, import_cameras) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
const aiScene* scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/cameras/Cameras.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
|
|
|
}
|
|
|
|
|
2019-10-08 12:05:05 +00:00
|
|
|
TEST_F(utglTF2ImportExport, incorrect_vertex_arrays) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
const aiScene* scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/IncorrectVertexArrays/Cube.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumVertices, 36u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[0]->mNumFaces, 12u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[1]->mNumVertices, 35u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[1]->mNumFaces, 11u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[2]->mNumVertices, 36u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[2]->mNumFaces, 18u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[3]->mNumVertices, 35u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[3]->mNumFaces, 17u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[4]->mNumVertices, 36u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[4]->mNumFaces, 12u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[5]->mNumVertices, 35u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[5]->mNumFaces, 11u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[6]->mNumVertices, 36u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[6]->mNumFaces, 18u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[7]->mNumVertices, 35u);
|
|
|
|
EXPECT_EQ(scene->mMeshes[7]->mNumFaces, 17u);
|
|
|
|
}
|
|
|
|
|
2019-11-14 20:15:30 +00:00
|
|
|
TEST_F( utglTF2ImportExport, texture_transform_test ) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/textureTransform/TextureTransformTest.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
|
|
|
EXPECT_NE(nullptr, scene);
|
|
|
|
}
|
|
|
|
|
2017-09-12 13:57:58 +00:00
|
|
|
#ifndef ASSIMP_BUILD_NO_EXPORT
|
|
|
|
TEST_F( utglTF2ImportExport, exportglTF2FromFileTest ) {
|
|
|
|
EXPECT_TRUE( exporterTest() );
|
|
|
|
}
|
2018-05-12 06:39:22 +00:00
|
|
|
|
2019-08-28 17:42:49 +00:00
|
|
|
TEST_F( utglTF2ImportExport, crash_in_anim_mesh_destructor ) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
const aiScene *scene = importer.ReadFile( ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Sample-Models/AnimatedMorphCube-glTF/AnimatedMorphCube.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
|
|
|
ASSERT_NE( nullptr, scene );
|
|
|
|
Assimp::Exporter exporter;
|
|
|
|
ASSERT_EQ(aiReturn_SUCCESS, exporter.Export(scene, "glb2", ASSIMP_TEST_MODELS_DIR "/glTF2/glTF-Sample-Models/AnimatedMorphCube-glTF/AnimatedMorphCube_out.glTF"));
|
|
|
|
}
|
|
|
|
|
2019-11-18 16:57:01 +00:00
|
|
|
TEST_F(utglTF2ImportExport, error_string_preserved) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/MissingBin/BoxTextured.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
|
|
|
ASSERT_EQ(nullptr, scene);
|
|
|
|
std::string error = importer.GetErrorString();
|
|
|
|
ASSERT_NE(error.find("BoxTextured0.bin"), std::string::npos) << "Error string should contain an error about missing .bin file";
|
|
|
|
}
|
|
|
|
|
2017-09-12 13:57:58 +00:00
|
|
|
#endif // ASSIMP_BUILD_NO_EXPORT
|
2019-12-12 12:06:36 +00:00
|
|
|
|
2019-12-05 14:05:49 +00:00
|
|
|
TEST_F(utglTF2ImportExport, sceneMetadata) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTextured-glTF/BoxTextured.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
|
|
|
ASSERT_NE(scene, nullptr);
|
|
|
|
ASSERT_NE(scene->mMetaData, nullptr);
|
|
|
|
{
|
|
|
|
ASSERT_TRUE(scene->mMetaData->HasKey(AI_METADATA_SOURCE_FORMAT));
|
|
|
|
aiString format;
|
|
|
|
ASSERT_TRUE(scene->mMetaData->Get(AI_METADATA_SOURCE_FORMAT, format));
|
|
|
|
ASSERT_EQ(strcmp(format.C_Str(), "glTF2 Importer"), 0);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
ASSERT_TRUE(scene->mMetaData->HasKey(AI_METADATA_SOURCE_FORMAT_VERSION));
|
|
|
|
aiString version;
|
|
|
|
ASSERT_TRUE(scene->mMetaData->Get(AI_METADATA_SOURCE_FORMAT_VERSION, version));
|
|
|
|
ASSERT_EQ(strcmp(version.C_Str(), "2.0"), 0);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
ASSERT_TRUE(scene->mMetaData->HasKey(AI_METADATA_SOURCE_GENERATOR));
|
|
|
|
aiString generator;
|
|
|
|
ASSERT_TRUE(scene->mMetaData->Get(AI_METADATA_SOURCE_GENERATOR, generator));
|
|
|
|
ASSERT_EQ(strcmp(generator.C_Str(), "COLLADA2GLTF"), 0);
|
|
|
|
}
|
|
|
|
}
|
2019-12-12 12:19:02 +00:00
|
|
|
|
2019-12-12 12:06:36 +00:00
|
|
|
TEST_F(utglTF2ImportExport, texcoords) {
|
|
|
|
Assimp::Importer importer;
|
|
|
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/glTF2/BoxTexcoords-glTF/boxTexcoords.gltf",
|
|
|
|
aiProcess_ValidateDataStructure);
|
|
|
|
ASSERT_NE(scene, nullptr);
|
|
|
|
|
|
|
|
ASSERT_TRUE(scene->HasMaterials());
|
|
|
|
const aiMaterial *material = scene->mMaterials[0];
|
|
|
|
|
|
|
|
aiString path;
|
|
|
|
aiTextureMapMode modes[2];
|
|
|
|
EXPECT_EQ(aiReturn_SUCCESS, material->GetTexture(aiTextureType_DIFFUSE, 0, &path, nullptr, nullptr,
|
|
|
|
nullptr, nullptr, modes));
|
|
|
|
EXPECT_STREQ(path.C_Str(), "texture.png");
|
|
|
|
|
|
|
|
int uvIndex = -1;
|
|
|
|
EXPECT_EQ(aiGetMaterialInteger(material, AI_MATKEY_GLTF_TEXTURE_TEXCOORD(aiTextureType_DIFFUSE, 0), &uvIndex), aiReturn_SUCCESS);
|
|
|
|
EXPECT_EQ(uvIndex, 0);
|
|
|
|
|
|
|
|
// Using manual macro expansion of AI_MATKEY_GLTF_PBRMETALLICROUGHNESS_METALLICROUGHNESS_TEXTURE here.
|
|
|
|
// The following works with some but not all compilers:
|
|
|
|
// #define APPLY(X, Y) X(Y)
|
|
|
|
// ..., APPLY(AI_MATKEY_GLTF_TEXTURE_TEXCOORD, AI_MATKEY_GLTF_PBRMETALLICROUGHNESS_METALLICROUGHNESS_TEXTURE), ...
|
|
|
|
EXPECT_EQ(aiGetMaterialInteger(material, AI_MATKEY_GLTF_TEXTURE_TEXCOORD(aiTextureType_UNKNOWN, 0), &uvIndex), aiReturn_SUCCESS);
|
|
|
|
EXPECT_EQ(uvIndex, 1);
|
|
|
|
}
|