Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
U
uniset2
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
1
Issues
1
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
UniSet project repositories
uniset2
Commits
e389830c
Commit
e389830c
authored
Jan 07, 2017
by
Pavel Vainerman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(REST API): тесты /consumers и /lost
parent
9915996b
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
82 additions
and
2 deletions
+82
-2
TODO
TODO
+3
-0
test_restapi_uniset.cc
extensions/tests/test_restapi_uniset.cc
+79
-2
No files found.
TODO
View file @
e389830c
...
@@ -98,6 +98,9 @@ DB: Сделать регулируемый буфер на INSERT-ы БД, чт
...
@@ -98,6 +98,9 @@ DB: Сделать регулируемый буфер на INSERT-ы БД, чт
- ведение статистики по типам сообщений в каждом объекте (и в SM). Чтобы увидеть где происходит потеря пакетов (если происходит).
- ведение статистики по типам сообщений в каждом объекте (и в SM). Чтобы увидеть где происходит потеря пакетов (если происходит).
(т.е. идея в том, что сколько "успешно" послала SM столько должно придти и быть обработано (разные счётчики) в объекте)
(т.е. идея в том, что сколько "успешно" послала SM столько должно придти и быть обработано (разные счётчики) в объекте)
- NoSQL база (в памяти) как буфер (держит интенсивную запись) перед "не спешной" записью в реляционную (MySQL,Postgre и т.п.)
==================
==================
lock-free: mentomic
lock-free: mentomic
...
...
extensions/tests/test_restapi_uniset.cc
View file @
e389830c
...
@@ -239,8 +239,85 @@ TEST_CASE("[REST API: /sensors]", "[restapi][sensors]")
...
@@ -239,8 +239,85 @@ TEST_CASE("[REST API: /sensors]", "[restapi][sensors]")
}
}
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
//if( req == "consumers" )
TEST_CASE
(
"[REST API: /consumers]"
,
"[restapi][consumers]"
)
//if( req == "lost"
{
init_test
();
// QUERY: /consumers
// Ожидаемый формат ответа:
// {"object":{"id":5003,"isActive":true,"lostMessages":0,"maxSizeOfMessageQueue":1000,"msgCount":0,"name":"SharedMemory","objectType":"IONotifyController"},
// "sensors":[
// {"consumers":[
// {"attempt":10,"id":6000,"lostEvents":0,"name":"TestProc","node":3000,"node_name":"localhost","smCount":0}
// ],
// "sensor":{"id":1,"name":"Input1_S"}},
// {"consumers":[
// {"attempt":4,"id":6000,"lostEvents":4,"name":"TestProc","node":3000,"node_name":"localhost","smCount":0}
// ],
// "sensor":{"id":10,"name":"AI_AS"}}
// ]}
std
::
string
s
=
shm
->
apiRequest
(
"/consumers"
);
Poco
::
JSON
::
Parser
parser
;
auto
result
=
parser
.
parse
(
s
);
Poco
::
JSON
::
Object
::
Ptr
json
=
result
.
extract
<
Poco
::
JSON
::
Object
::
Ptr
>
();
REQUIRE
(
json
);
auto
jarr
=
json
->
get
(
"sensors"
).
extract
<
Poco
::
JSON
::
Array
::
Ptr
>
();
REQUIRE
(
jarr
);
auto
jret
=
jarr
->
getObject
(
0
);
REQUIRE
(
jret
);
auto
sens
=
jret
->
get
(
"sensor"
).
extract
<
Poco
::
JSON
::
Object
::
Ptr
>
();
REQUIRE
(
sens
);
REQUIRE
(
sens
->
get
(
"id"
).
convert
<
ObjectId
>
()
==
1
);
REQUIRE
(
sens
->
get
(
"name"
).
convert
<
std
::
string
>
()
==
"Input1_S"
);
auto
cons
=
jret
->
get
(
"consumers"
).
extract
<
Poco
::
JSON
::
Array
::
Ptr
>
();
REQUIRE
(
cons
);
REQUIRE
(
cons
->
size
()
==
1
);
}
// -----------------------------------------------------------------------------
TEST_CASE
(
"[REST API: /lost]"
,
"[restapi][lost]"
)
{
init_test
();
// QUERY: /lost
// Ожидаемый формат ответа:
// {"lost consumers":[
// ...
// ],
// "object":{"id":5003,"isActive":true,"lostMessages":0,"maxSizeOfMessageQueue":1000,"msgCount":0,"name":"SharedMemory","objectType":"IONotifyController"}
// }
// Сперва имитируем зазачика (который "исчезнет").
const
ObjectId
myID
=
6013
;
// TestProc2
const
ObjectId
sid
=
122
;
// test sensor
shm
->
askSensor
(
sid
,
UniversalIO
::
UIONotify
,
myID
);
// имитируем изменения
for
(
size_t
i
=
200
;
i
<
220
;
i
++
)
shm
->
setValue
(
sid
,
i
);
// проверяем список "потерянных"
std
::
string
s
=
shm
->
apiRequest
(
"/lost"
);
Poco
::
JSON
::
Parser
parser
;
auto
result
=
parser
.
parse
(
s
);
Poco
::
JSON
::
Object
::
Ptr
json
=
result
.
extract
<
Poco
::
JSON
::
Object
::
Ptr
>
();
REQUIRE
(
json
);
auto
jarr
=
json
->
get
(
"lost consumers"
).
extract
<
Poco
::
JSON
::
Array
::
Ptr
>
();
REQUIRE
(
jarr
);
auto
jret
=
jarr
->
getObject
(
0
);
REQUIRE
(
jret
);
REQUIRE
(
jret
->
get
(
"id"
).
convert
<
ObjectId
>
()
==
myID
);
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
#endif // ifndef DISABLE_REST_API
#endif // ifndef DISABLE_REST_API
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment