Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
C
caosdb-cppinttest
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Container registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
caosdb
Software
caosdb-cppinttest
Merge requests
!27
F grpc select
Code
Review changes
Check out branch
Download
Patches
Plain diff
Merged
F grpc select
f-grpc-select
into
dev
Overview
2
Commits
10
Pipelines
20
Changes
1
Merged
Timm Fitschen
requested to merge
f-grpc-select
into
dev
2 years ago
Overview
2
Commits
10
Pipelines
20
Changes
1
Expand
Summary
Tests for
caosdb-server!72 (merged)
and
caosdb-cpplib!44 (merged)
0
0
Merge request reports
Viewing commit
27fc8af1
Prev
Next
Show latest version
1 file
+
82
−
3
Side-by-side
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
Verified
27fc8af1
WIP: SELECT for GRPC API
· 27fc8af1
Timm Fitschen
authored
2 years ago
test/test_select.cpp
+
82
−
3
Options
@@ -20,28 +20,107 @@
@@ -20,28 +20,107 @@
*
*
*/
*/
#include
"caosdb/connection.h"
// for Connection, ConnectionManager
#include
"caosdb/connection.h"
// for Connection, ConnectionManager
#include
"caosdb/data_type.h"
// for AtomicDataType
#include
"caosdb/transaction.h"
// for Transaction, ResultTable
#include
"caosdb/transaction.h"
// for Transaction, ResultTable
#include
"caosdb/value.h"
// for Value
#include
<gtest/gtest-message.h>
// for Message
#include
<gtest/gtest-message.h>
// for Message
#include
<gtest/gtest-test-part.h>
// for SuiteApiResolver, TestFactoryImpl
#include
<gtest/gtest-test-part.h>
// for SuiteApiResolver, TestFactoryImpl
#include
<gtest/gtest_pred_impl.h>
// for Test, TestInfo, EXPECT_EQ, TEST
#include
<gtest/gtest_pred_impl.h>
// for Test, TestInfo, EXPECT_EQ, TEST
#include
<memory>
// for allocator, unique_ptr, __shared_p...
#include
<memory>
// for allocator, unique_ptr, __shared_p...
//
//
namespace
caosdb
::
transaction
{
namespace
caosdb
::
transaction
{
using
caosdb
::
entity
::
AtomicDataType
;
using
caosdb
::
entity
::
Role
;
using
caosdb
::
entity
::
Property
;
using
caosdb
::
entity
::
Parent
;
using
caosdb
::
entity
::
Entity
;
using
caosdb
::
entity
::
Value
;
class
test_select
:
public
::
testing
::
Test
{
public:
static
void
DeleteEntities
()
{
// delete all entities
const
auto
&
connection
=
caosdb
::
connection
::
ConnectionManager
::
GetDefaultConnection
();
auto
query_transaction
(
connection
->
CreateTransaction
());
query_transaction
->
Query
(
"FIND Test*"
);
query_transaction
->
Execute
();
if
(
query_transaction
->
GetResultSet
().
size
()
>
0
)
{
std
::
cout
<<
"Cleanup: Deleting "
<<
query_transaction
->
GetResultSet
().
size
()
<<
" entities."
<<
std
::
endl
;
auto
delete_transaction
(
connection
->
CreateTransaction
());
for
(
const
Entity
&
entity
:
query_transaction
->
GetResultSet
())
{
delete_transaction
->
DeleteById
(
entity
.
GetId
());
}
delete_transaction
->
Execute
();
}
}
static
auto
CreateTestProp
()
->
Entity
{
Entity
entity
;
entity
.
SetRole
(
Role
::
PROPERTY
);
entity
.
SetName
(
"TestProp"
);
entity
.
SetDataType
(
AtomicDataType
::
TEXT
);
return
entity
;
}
static
auto
CreateTestRT
()
->
Entity
{
Entity
entity
;
entity
.
SetRole
(
Role
::
RECORD_TYPE
);
entity
.
SetName
(
"TestRT"
);
return
entity
;
}
static
auto
CreateRecord
(
const
std
::
string
&
property_name
,
Value
value
)
->
Entity
{
Entity
entity
;
entity
.
SetRole
(
Role
::
RECORD
);
Parent
parent
;
parent
.
SetName
(
"TestRT"
);
entity
.
AppendParent
(
parent
);
Property
property
;
property
.
SetName
(
property_name
);
property
.
SetValue
(
value
);
entity
.
AppendProperty
(
property
);
return
entity
;
}
protected
:
// Fixture methods //////////////////////////////////////////////////////////
void
SetUp
()
override
{
DeleteEntities
();
const
auto
&
connection
=
caosdb
::
connection
::
ConnectionManager
::
GetDefaultConnection
();
auto
insert_transaction
(
connection
->
CreateTransaction
());
insert_transaction
->
InsertEntity
(
CreateTestRT
());
insert_transaction
->
InsertEntity
(
CreateTestProp
());
insert_transaction
->
Execute
();
}
void
TearDown
()
override
{
DeleteEntities
();
}
};
/*
/*
* Test select query on empty database.
* Test select query on empty database.
*/
*/
TEST
(
test_
transaction
,
test_select
)
{
TEST
_F
(
test_
select
,
test_select
_name
)
{
const
auto
&
connection
=
caosdb
::
connection
::
ConnectionManager
::
GetDefaultConnection
();
const
auto
&
connection
=
caosdb
::
connection
::
ConnectionManager
::
GetDefaultConnection
();
auto
query_transaction
(
connection
->
CreateTransaction
());
auto
query_transaction
(
connection
->
CreateTransaction
());
query_transaction
->
Query
(
"SELECT name FROM
ENTITY WITH id > 99
"
);
query_transaction
->
Query
(
"SELECT name FROM
RecordType TestRT
"
);
query_transaction
->
Execute
();
query_transaction
->
Execute
();
EXPECT_EQ
(
query_transaction
->
GetResultTable
().
size
(),
0
);
EXPECT_EQ
(
query_transaction
->
GetResultTable
().
GetHeader
().
size
(),
1
);
EXPECT_EQ
(
query_transaction
->
GetResultTable
().
GetHeader
().
size
(),
1
);
for
(
const
auto
&
column
:
query_transaction
->
GetResultTable
().
GetHeader
())
{
for
(
const
auto
&
column
:
query_transaction
->
GetResultTable
().
GetHeader
())
{
EXPECT_EQ
(
column
.
GetName
(),
"name"
);
EXPECT_EQ
(
column
.
GetName
(),
"name"
);
}
}
EXPECT_EQ
(
query_transaction
->
GetResultTable
().
size
(),
1
);
for
(
const
auto
&
row
:
query_transaction
->
GetResultTable
().
GetRows
())
{
EXPECT_EQ
(
row
.
GetValue
(
"name"
).
GetAsString
(),
"bla"
);
}
}
}
}
// namespace caosdb::transaction
}
// namespace caosdb::transaction
Loading