2022-08-23 18:47:56 +00:00
|
|
|
/******************************TRICK HEADER*************************************
|
|
|
|
PURPOSE: ( Tests for the VariableServerSession class )
|
|
|
|
*******************************************************************************/
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
2023-03-20 22:53:01 +00:00
|
|
|
#include <gmock/gmock.h>
|
|
|
|
|
2022-08-23 18:47:56 +00:00
|
|
|
#include <iostream>
|
|
|
|
#include <iomanip>
|
|
|
|
#include <limits>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "trick/MemoryManager.hh"
|
|
|
|
#include "trick/UdUnits.hh"
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
|
|
|
|
#include "trick/message_type.h"
|
2022-08-23 18:47:56 +00:00
|
|
|
#include "trick/VariableServerSession.hh"
|
|
|
|
#include "trick/var_binary_parser.hh"
|
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
#include "trick/Mock/MockExecutive.hh"
|
|
|
|
#include "trick/Mock/MockRealtimeSync.hh"
|
|
|
|
#include "trick/Mock/MockMessagePublisher.hh"
|
|
|
|
#include "trick/Mock/MockMessageCustomManager.hh"
|
|
|
|
#include "trick/Mock/MockInputProcessor.hh"
|
|
|
|
#include "trick/Mock/MockClientConnection.hh"
|
|
|
|
#include "trick/Mock/MockVariableServerSession.hh"
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
using ::testing::AtLeast;
|
|
|
|
using ::testing::_;
|
|
|
|
using ::testing::Truly;
|
|
|
|
using ::testing::Args;
|
|
|
|
using ::testing::Return;
|
|
|
|
using ::testing::Invoke;
|
2023-04-18 21:27:32 +00:00
|
|
|
using ::testing::DoAll;
|
|
|
|
using ::testing::SetArgReferee;
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
|
2022-08-23 18:47:56 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
Test Fixture.
|
|
|
|
*/
|
|
|
|
class VariableServerSession_test : public ::testing::Test {
|
|
|
|
protected:
|
2023-04-18 21:27:32 +00:00
|
|
|
// MemoryManager isn't actually a dependency, VariableReference is
|
|
|
|
// But using the memory manage is much easier than mocking VariableReference all the way
|
|
|
|
// Which is bad design @me
|
|
|
|
// shame
|
|
|
|
Trick::MemoryManager memmgr;
|
|
|
|
|
|
|
|
// Dependencies
|
|
|
|
MockRealtimeSync realtime_sync;
|
|
|
|
MockExecutive executive;
|
|
|
|
MockMessagePublisher message_publisher;
|
|
|
|
MockMessageCustomManager message_custom;
|
|
|
|
MockInputProcessor input_processor;
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
MockClientConnection connection;
|
2022-08-23 18:47:56 +00:00
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
VariableServerSession_test() {}
|
2022-08-23 18:47:56 +00:00
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
~VariableServerSession_test() {}
|
2023-03-20 22:53:01 +00:00
|
|
|
|
2022-08-23 18:47:56 +00:00
|
|
|
void SetUp() {}
|
|
|
|
void TearDown() {}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, toString) {
|
|
|
|
|
|
|
|
int a = 5;
|
|
|
|
double b = 6;
|
|
|
|
std::string c = "Hello";
|
2023-04-18 21:27:32 +00:00
|
|
|
(void) memmgr.declare_extern_var(&a, "int a");
|
|
|
|
(void) memmgr.declare_extern_var(&b, "double b");
|
|
|
|
(void) memmgr.declare_extern_var(&c, "std::string c");
|
2022-08-23 18:47:56 +00:00
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
Trick::VariableServerSession session;
|
2022-08-23 18:47:56 +00:00
|
|
|
|
|
|
|
session.var_add("a");
|
|
|
|
session.var_add("b");
|
|
|
|
session.var_add("c");
|
|
|
|
session.var_binary();
|
|
|
|
|
|
|
|
std::stringstream ss;
|
|
|
|
ss << session;
|
|
|
|
|
|
|
|
std::string expected = " \"format\":\"BINARY\",\n \"update_rate\":0.1,\n \"variables\":[\n \"a\",\n \"b\",\n \"c\"\n ]\n";
|
|
|
|
EXPECT_EQ(ss.str(), expected);
|
|
|
|
|
|
|
|
session.var_ascii();
|
|
|
|
expected = " \"format\":\"ASCII\",\n \"update_rate\":0.1,\n \"variables\":[\n \"a\",\n \"b\",\n \"c\"\n ]\n";
|
|
|
|
ss.str("");
|
|
|
|
ss << session;
|
|
|
|
EXPECT_EQ(ss.str(), expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, var_sync) {
|
|
|
|
// ARRANGE
|
2023-03-20 22:53:01 +00:00
|
|
|
Trick::VariableServerSession session;
|
2022-08-23 18:47:56 +00:00
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.var_sync(0);
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_EQ(session.get_copy_mode(), VS_COPY_ASYNC);
|
|
|
|
ASSERT_EQ(session.get_write_mode(), VS_WRITE_ASYNC);
|
|
|
|
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.var_sync(1);
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_EQ(session.get_copy_mode(), VS_COPY_SCHEDULED);
|
|
|
|
ASSERT_EQ(session.get_write_mode(), VS_WRITE_ASYNC);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.var_sync(2);
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_EQ(session.get_copy_mode(), VS_COPY_SCHEDULED);
|
|
|
|
ASSERT_EQ(session.get_write_mode(), VS_WRITE_WHEN_COPIED);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, large_message_ascii) {
|
|
|
|
// ARRANGE
|
2023-03-20 22:53:01 +00:00
|
|
|
Trick::VariableServerSession session;
|
|
|
|
session.set_connection(&connection);
|
2022-08-23 18:47:56 +00:00
|
|
|
|
|
|
|
const static int big_arr_size = 4000;
|
|
|
|
// Make an array too big to fit in a single message
|
|
|
|
|
|
|
|
int big_arr[big_arr_size];
|
|
|
|
for (int i = 0; i < big_arr_size; i++) {
|
|
|
|
big_arr[i] = i;
|
|
|
|
}
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Set it up with the memory manager
|
2023-04-18 21:27:32 +00:00
|
|
|
(void) memmgr.declare_extern_var(&big_arr, "int big_arr[4000]");
|
2022-08-23 18:47:56 +00:00
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Create references for all of them
|
|
|
|
std::vector <Trick::VariableReference *> vars;
|
2022-08-23 18:47:56 +00:00
|
|
|
for (int i = 0; i < big_arr_size; i++) {
|
|
|
|
std::string var_name = "big_arr[" + std::to_string(i) + "]";
|
2023-03-20 22:53:01 +00:00
|
|
|
Trick::VariableReference * var = new Trick::VariableReference(var_name);
|
|
|
|
var->stageValue();
|
|
|
|
vars.push_back(var);
|
2022-08-23 18:47:56 +00:00
|
|
|
}
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Make a matcher for the Mock
|
|
|
|
// This will check that the messages that are passed into connection.write() are correct
|
|
|
|
int val_counter = 0;
|
|
|
|
int message_counter = 0;
|
|
|
|
int final_val = 0;
|
|
|
|
auto constructedCorrectly = [&] (std::string s) -> bool {
|
|
|
|
std::stringstream ss(s);
|
2022-08-23 18:47:56 +00:00
|
|
|
std::string token;
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
if (message_counter == 0) {
|
|
|
|
// First val in first message should be the message type, 0
|
2022-08-23 18:47:56 +00:00
|
|
|
std::getline(ss, token, '\t');
|
|
|
|
int message_type = stoi(token);
|
2023-03-20 22:53:01 +00:00
|
|
|
if (message_type != 0) return false;
|
|
|
|
} else {
|
|
|
|
// First val in all other message should be (last val in previous message)+1
|
|
|
|
std::getline(ss, token, '\t');
|
|
|
|
int first_num = stoi(token);
|
|
|
|
if (first_num != final_val+1) return false;
|
|
|
|
val_counter++;
|
2022-08-23 18:47:56 +00:00
|
|
|
}
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
int num = 0;
|
|
|
|
|
|
|
|
// The rest of the message should just be sequential
|
2022-08-23 18:47:56 +00:00
|
|
|
while (std::getline(ss, token, '\t')) {
|
|
|
|
if (token == "\n") { break; }
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
num = stoi(token);
|
|
|
|
if (val_counter != num) return false;
|
|
|
|
val_counter++;
|
2022-08-23 18:47:56 +00:00
|
|
|
}
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Save the final value so that we can verify the next message starts correctly
|
|
|
|
final_val = num;
|
|
|
|
message_counter++;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Set up the mock connection - it should make 3 calls to write
|
|
|
|
// The constructedCorrectly matcher will ensure that the values passed in are what we want them to be
|
|
|
|
EXPECT_CALL(connection, write(Truly(constructedCorrectly)))
|
|
|
|
.Times(3);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.write_data(vars, (VS_MESSAGE_TYPE) 0);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
// Make sure that the entire message was written out
|
|
|
|
ASSERT_EQ(val_counter, big_arr_size);
|
2022-08-23 18:47:56 +00:00
|
|
|
}
|
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
TEST_F(VariableServerSession_test, large_message_binary) {
|
2022-08-23 18:47:56 +00:00
|
|
|
// ARRANGE
|
2023-03-20 22:53:01 +00:00
|
|
|
Trick::VariableServerSession session;
|
|
|
|
session.set_connection(&connection);
|
2022-08-23 18:47:56 +00:00
|
|
|
session.var_binary();
|
|
|
|
|
|
|
|
const static int big_arr_size = 4000;
|
|
|
|
// Make an array too big to fit in a single message
|
|
|
|
|
|
|
|
int big_arr[big_arr_size];
|
|
|
|
for (int i = 0; i < big_arr_size; i++) {
|
|
|
|
big_arr[i] = i;
|
|
|
|
}
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Set it up with the memory manager
|
2023-04-18 21:27:32 +00:00
|
|
|
(void) memmgr.declare_extern_var(&big_arr, "int big_arr[4000]");
|
2022-08-23 18:47:56 +00:00
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Create references for all of them
|
|
|
|
std::vector <Trick::VariableReference *> vars;
|
2022-08-23 18:47:56 +00:00
|
|
|
for (int i = 0; i < big_arr_size; i++) {
|
|
|
|
std::string var_name = "big_arr[" + std::to_string(i) + "]";
|
2023-03-20 22:53:01 +00:00
|
|
|
Trick::VariableReference * var = new Trick::VariableReference(var_name);
|
|
|
|
var->stageValue();
|
|
|
|
vars.push_back(var);
|
2022-08-23 18:47:56 +00:00
|
|
|
}
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Create a matcher that parses and collects the arguments into a ParsedBinaryMessage
|
2022-08-23 18:47:56 +00:00
|
|
|
ParsedBinaryMessage full_message;
|
2023-03-20 22:53:01 +00:00
|
|
|
auto binaryConstructedCorrectly = [&] (std::tuple<char *, int> msg_tuple) -> bool {
|
|
|
|
char * message;
|
|
|
|
int size;
|
|
|
|
std::tie(message, size) = msg_tuple;
|
2022-08-23 18:47:56 +00:00
|
|
|
ParsedBinaryMessage partial_message;
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
// Put the message into a vector the parser
|
|
|
|
std::vector<unsigned char> bytes;
|
|
|
|
for (int i = 0; i < size; i++) {
|
|
|
|
bytes.push_back(message[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Parse and add it to the full message
|
|
|
|
try {
|
|
|
|
partial_message.parse(bytes);
|
|
|
|
full_message.combine(partial_message);
|
|
|
|
} catch (const MalformedMessageException& ex) {
|
|
|
|
std::cout << "Parser failed with message: " << ex.what();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Set up the mock connection - it should make a bunch of calls to write
|
|
|
|
// The constructedCorrectly matcher will ensure that the values passed in are what we want them to be
|
|
|
|
EXPECT_CALL(connection, write(_, _)).With(Args<0,1>(Truly(binaryConstructedCorrectly))).Times(AtLeast(3));
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.write_data(vars, (VS_MESSAGE_TYPE) 0);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
|
|
|
|
// Make sure we got all of the values
|
2022-08-23 18:47:56 +00:00
|
|
|
ASSERT_EQ(full_message.getNumVars(), big_arr_size);
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
// Make sure all of the values are correct and have names
|
2022-08-23 18:47:56 +00:00
|
|
|
for (int i = 0; i < big_arr_size; i++) {
|
|
|
|
try {
|
|
|
|
std::string var_name = "big_arr[" + std::to_string(i) + "]";
|
|
|
|
Var variable = full_message.getVariable(var_name);
|
|
|
|
|
|
|
|
EXPECT_EQ(variable.getValue<int>(), i);
|
|
|
|
} catch (std::exception& ex) {
|
|
|
|
FAIL() << ex.what();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-03-20 22:53:01 +00:00
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
TEST_F(VariableServerSession_test, log_on) {
|
|
|
|
// ARRANGE
|
|
|
|
int fake_logstream = 200;
|
|
|
|
|
|
|
|
Trick::VariableServerSession session;
|
|
|
|
session.set_connection(&connection);
|
|
|
|
|
|
|
|
// Expect the per-session logfile to be opened
|
|
|
|
EXPECT_CALL(message_custom, open_custom_message_file(_, _, _))
|
|
|
|
.WillOnce(Return(fake_logstream));
|
|
|
|
|
|
|
|
// Expect a write to the log via message_publish
|
|
|
|
EXPECT_CALL(message_publisher, publish(MSG_PLAYBACK,_));
|
|
|
|
EXPECT_CALL(message_publisher, publish(fake_logstream,_));
|
|
|
|
|
|
|
|
// Just get whatever from the client
|
|
|
|
EXPECT_CALL(connection, read(_, _))
|
|
|
|
.WillOnce(DoAll(SetArgReferee<0>("some_python_command"), Return(10)));
|
|
|
|
EXPECT_CALL(connection, getClientTag())
|
|
|
|
.WillRepeatedly(Return("ClientTag"));
|
|
|
|
EXPECT_CALL(input_processor, parse(_));
|
|
|
|
|
|
|
|
// ACT
|
2023-04-28 20:42:42 +00:00
|
|
|
session.set_log(true);
|
|
|
|
session.set_session_log(true);
|
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
session.handle_message();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, no_log_by_default) {
|
|
|
|
// ARRANGE
|
|
|
|
Trick::VariableServerSession session;
|
|
|
|
session.set_connection(&connection);
|
|
|
|
|
|
|
|
// Should not get any write to the log
|
|
|
|
EXPECT_CALL(message_publisher, publish(MSG_PLAYBACK,_))
|
|
|
|
.Times(0);
|
|
|
|
// Just get whatever from the client
|
|
|
|
EXPECT_CALL(connection, read(_, _))
|
|
|
|
.WillOnce(DoAll(SetArgReferee<0>("some_python_command"), Return(10)));
|
|
|
|
EXPECT_CALL(input_processor, parse(_));
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.handle_message();
|
|
|
|
// ASSERT
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, info_msg_on) {
|
|
|
|
// ARRANGE
|
|
|
|
Trick::VariableServerSession session;
|
|
|
|
session.set_connection(&connection);
|
|
|
|
|
|
|
|
// Expect a write to info message_publish
|
|
|
|
EXPECT_CALL(message_publisher, publish(MSG_DEBUG,_));
|
|
|
|
// Just get whatever from the client
|
|
|
|
EXPECT_CALL(connection, read(_, _))
|
|
|
|
.WillOnce(DoAll(SetArgReferee<0>("some_python_command"), Return(10)));
|
|
|
|
EXPECT_CALL(connection, getClientTag())
|
|
|
|
.WillOnce(Return("ClientTag"));
|
|
|
|
EXPECT_CALL(input_processor, parse(_));
|
|
|
|
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.set_info_message(true);
|
|
|
|
session.handle_message();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, info_msg_off_by_default) {
|
|
|
|
// ARRANGE
|
|
|
|
Trick::VariableServerSession session;
|
|
|
|
session.set_connection(&connection);
|
|
|
|
|
|
|
|
// Expect no write to info message_publish
|
|
|
|
EXPECT_CALL(message_publisher, publish(MSG_DEBUG,_))
|
|
|
|
.Times(0);
|
|
|
|
// Just get whatever from the client
|
|
|
|
EXPECT_CALL(connection, read(_, _))
|
|
|
|
.WillOnce(DoAll(SetArgReferee<0>("some_python_command"), Return(10)));
|
|
|
|
EXPECT_CALL(input_processor, parse(_));
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.handle_message();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, debug_on) {
|
|
|
|
// ARRANGE
|
|
|
|
Trick::VariableServerSession session;
|
|
|
|
session.set_connection(&connection);
|
|
|
|
|
|
|
|
// Expect 2 writes to info message_publish
|
|
|
|
EXPECT_CALL(message_publisher, publish(MSG_DEBUG,_))
|
|
|
|
.Times(2);
|
|
|
|
// Just get whatever from the client
|
|
|
|
EXPECT_CALL(connection, read(_, _))
|
|
|
|
.WillOnce(DoAll(SetArgReferee<0>("some_python_command"), Return(10)));
|
|
|
|
EXPECT_CALL(input_processor, parse(_));
|
|
|
|
EXPECT_CALL(connection, getClientTag())
|
|
|
|
.WillRepeatedly(Return("ClientTag"));
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
session.var_debug(3);
|
|
|
|
session.handle_message();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
}
|
|
|
|
|
|
|
|
/**************************************************************************/
|
|
|
|
/* Mode tests */
|
|
|
|
/**************************************************************************/
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
void setup_partial_session_mock(MockVariableServerSession& session) {
|
|
|
|
EXPECT_CALL(session, copy_and_write_async())
|
|
|
|
.WillOnce(Invoke(&session, &MockVariableServerSession::copy_and_write_async_concrete));
|
|
|
|
}
|
|
|
|
|
|
|
|
void set_session_modes(MockVariableServerSession& session, VS_COPY_MODE copy_mode, VS_WRITE_MODE write_mode, bool pause) {
|
|
|
|
EXPECT_CALL(session, get_copy_mode())
|
|
|
|
.WillRepeatedly(Return(copy_mode));
|
|
|
|
EXPECT_CALL(session, get_write_mode())
|
|
|
|
.WillRepeatedly(Return(write_mode));
|
|
|
|
EXPECT_CALL(session, get_pause())
|
|
|
|
.WillOnce(Return(pause));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_async_disabled) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
setup_partial_session_mock(session);
|
|
|
|
|
|
|
|
// set disabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
|
|
|
|
// Nothing else should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
session.copy_and_write_async();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_async_copy_and_write) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
setup_partial_session_mock(session);
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
// Copy async, write when copied, not paused
|
|
|
|
set_session_modes(session, VS_COPY_ASYNC, VS_WRITE_ASYNC, false);
|
|
|
|
|
|
|
|
// Copy and write should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_async();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_GE(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_async_copy_write_when_copied) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
setup_partial_session_mock(session);
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
// Copy async, write when copied, not paused
|
|
|
|
set_session_modes(session, VS_COPY_ASYNC, VS_WRITE_WHEN_COPIED, false);
|
|
|
|
|
|
|
|
// Copy and write should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_async();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_GE(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_async_no_copy_or_write) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
setup_partial_session_mock(session);
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
// Copy async, write when copied, not paused
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
// Copy and write should not be called
|
2023-03-20 22:53:01 +00:00
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_async();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_GE(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_async_non_realtime) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
setup_partial_session_mock(session);
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
// Copy async, write async, paused
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(false));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
// Copy and write should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_async();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_GE(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_async_paused) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
setup_partial_session_mock(session);
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
// Copy async, write async, paused
|
|
|
|
set_session_modes(session, VS_COPY_ASYNC, VS_WRITE_ASYNC, true);
|
|
|
|
|
|
|
|
// Copy and write should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_async();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_GE(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_async_write_fails) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
setup_partial_session_mock(session);
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
// Copy async, write async, paused
|
|
|
|
set_session_modes(session, VS_COPY_ASYNC, VS_WRITE_ASYNC, false);
|
|
|
|
|
|
|
|
// Copy and write should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.WillOnce(Return(-1));
|
|
|
|
|
|
|
|
// Exit should be called
|
|
|
|
EXPECT_CALL(session, set_exit_cmd())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_async();
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
ASSERT_EQ(result, -1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_top_disabled) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set disabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
|
|
|
|
// Nothing else should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
session.copy_and_write_top(100);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_top_copy_top_write_async) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_ASYNC, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
EXPECT_CALL(session, get_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_top(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_top_copy_top_write_when_copied) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_top(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_top_copy_top_dont_write_if_non_realtime) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(false));
|
2023-03-20 22:53:01 +00:00
|
|
|
EXPECT_CALL(session, get_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_top(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_top_copy_top_write_paused) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_WHEN_COPIED, true);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_top(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_top_wrong_offset) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
EXPECT_CALL(session, get_copy_mode())
|
|
|
|
.WillRepeatedly(Return(VS_COPY_TOP_OF_FRAME));
|
|
|
|
EXPECT_CALL(session, get_write_mode())
|
|
|
|
.WillRepeatedly(Return(VS_WRITE_WHEN_COPIED));
|
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_top(101);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_disabled) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set disabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
|
|
|
|
// Nothing else should be called
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
session.copy_and_write_freeze(100);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_copy_top_write_async) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_ASYNC, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_copy_top_write_when_copied) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_copy_top_dont_write_if_non_realtime) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(false));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_copy_top_write_paused) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_TOP_OF_FRAME, VS_WRITE_WHEN_COPIED, true);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_wrong_offset) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
EXPECT_CALL(session, get_copy_mode())
|
|
|
|
.WillRepeatedly(Return(VS_COPY_TOP_OF_FRAME));
|
|
|
|
EXPECT_CALL(session, get_write_mode())
|
|
|
|
.WillRepeatedly(Return(VS_WRITE_WHEN_COPIED));
|
|
|
|
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_multiple())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
EXPECT_CALL(session, get_freeze_frame_offset())
|
|
|
|
.WillRepeatedly(Return(0));
|
|
|
|
|
|
|
|
// Should only copy
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze(101);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_disabled) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_wrong_mode) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
EXPECT_CALL(session, get_copy_mode())
|
|
|
|
.WillRepeatedly(Return(VS_COPY_TOP_OF_FRAME));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_wrong_tics) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
EXPECT_CALL(session, get_copy_mode())
|
|
|
|
.WillRepeatedly(Return(VS_COPY_TOP_OF_FRAME));
|
|
|
|
EXPECT_CALL(session, get_next_tics())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_copy_and_write) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_copy_scheduled_write_async) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_ASYNC, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_paused) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_ASYNC, true);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_non_realtime) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_ASYNC, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(false));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_scheduled_write_fails) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.WillOnce(Return(-1));
|
|
|
|
|
|
|
|
EXPECT_CALL(session, set_exit_cmd())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, -1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_disabled) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_wrong_mode) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
EXPECT_CALL(session, get_copy_mode())
|
|
|
|
.WillRepeatedly(Return(VS_COPY_TOP_OF_FRAME));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_wrong_tics) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(false));
|
|
|
|
EXPECT_CALL(session, get_copy_mode())
|
|
|
|
.WillRepeatedly(Return(VS_COPY_TOP_OF_FRAME));
|
|
|
|
EXPECT_CALL(session, get_freeze_next_tics())
|
|
|
|
.WillRepeatedly(Return(10));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_copy_and_write) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_copy_scheduled_write_async) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_ASYNC, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_paused) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_ASYNC, true);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_non_realtime) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_ASYNC, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(false));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
// Shouldn't do anything
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.Times(0);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_F(VariableServerSession_test, copy_and_write_freeze_scheduled_write_fails) {
|
|
|
|
// ARRANGE
|
|
|
|
MockVariableServerSession session;
|
|
|
|
|
|
|
|
// set enabled
|
|
|
|
EXPECT_CALL(session, get_enabled())
|
|
|
|
.WillOnce(Return(true));
|
|
|
|
|
|
|
|
set_session_modes(session, VS_COPY_SCHEDULED, VS_WRITE_WHEN_COPIED, false);
|
2023-04-18 21:27:32 +00:00
|
|
|
EXPECT_CALL(realtime_sync, is_active())
|
|
|
|
.WillRepeatedly(Return(true));
|
2023-03-20 22:53:01 +00:00
|
|
|
|
|
|
|
EXPECT_CALL(session, get_freeze_next_tics())
|
|
|
|
.WillRepeatedly(Return(100));
|
|
|
|
|
|
|
|
EXPECT_CALL(session, copy_sim_data())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
EXPECT_CALL(session, write_data())
|
|
|
|
.WillOnce(Return(-1));
|
|
|
|
|
|
|
|
EXPECT_CALL(session, set_exit_cmd())
|
|
|
|
.Times(1);
|
|
|
|
|
|
|
|
// ACT
|
|
|
|
int result = session.copy_and_write_freeze_scheduled(100);
|
|
|
|
|
|
|
|
// ASSERT
|
|
|
|
EXPECT_EQ(result, -1);
|
|
|
|
}
|