Skip to content

Commit

Permalink
Rename client_version->emitter_version and add config field.
Browse files Browse the repository at this point in the history
  • Loading branch information
dreamer-dead authored and Andrey Kraynov committed Nov 11, 2015
1 parent 3c37592 commit 89dee14
Show file tree
Hide file tree
Showing 6 changed files with 92 additions and 36 deletions.
20 changes: 5 additions & 15 deletions src/daemon/absorber.cc
Original file line number Diff line number Diff line change
Expand Up @@ -13,17 +13,6 @@ using namespace std::placeholders;
namespace dist_clang {
namespace daemon {

namespace {

bool ValidateClientVersion(ui32 client_version) {
return client_version >= Absorber::kMinGoodClientVersion;
}

} // namespace

// static
const ui32 Absorber::kMinGoodClientVersion = 100;

Absorber::Absorber(const proto::Configuration& configuration)
: CompilationDaemon(configuration) {
using Worker = base::WorkerPool::SimpleWorker;
Expand Down Expand Up @@ -78,11 +67,12 @@ bool Absorber::HandleNewMessage(net::ConnectionPtr connection,

if (message->HasExtension(proto::Remote::extension)) {
Message execute(message->ReleaseExtension(proto::Remote::extension));
if (!ValidateClientVersion(execute->client_version())) {
LOG(WARNING) << "Client sent a bad version: "
<< execute->client_version();
auto config = conf();
if (execute->emitter_version() < config->absorber().min_emitter_version()) {
LOG(WARNING) << "Emitter sent a bad version: "
<< execute->emitter_version();
net::proto::Status bad_version_status;
bad_version_status.set_code(net::proto::Status::BAD_CLIENT_VERSION);
bad_version_status.set_code(net::proto::Status::BAD_EMITTER_VERSION);
return connection->ReportStatus(bad_version_status);
}

Expand Down
2 changes: 0 additions & 2 deletions src/daemon/absorber.h
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,6 @@ namespace daemon {

class Absorber : public CompilationDaemon {
public:
static const ui32 kMinGoodClientVersion;

explicit Absorber(const proto::Configuration& configuration);
virtual ~Absorber();

Expand Down
78 changes: 72 additions & 6 deletions src/daemon/absorber_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -8,18 +8,24 @@ namespace daemon {

namespace {

static const ui32 kEmptyEmitterVersion = 0u;
static const ui32 kBadEmitterVersion = 1u;
static const ui32 kGoodEmitterVersion = 100u;

// S1..4 types can be one of the following: |String|, |Immutable|, |Literal|
template <typename S1, typename S2, typename S3, typename S4 = String>
net::Connection::ScopedMessage CreateMessage(
const S1& source,
const S2& action,
const S3& compiler_version,
const S4& language = S4(),
ui32 client_version = Absorber::kMinGoodClientVersion) {
ui32 emitter_version = kEmptyEmitterVersion) {
net::Connection::ScopedMessage message(new net::Connection::Message);
auto* extension = message->MutableExtension(proto::Remote::extension);
extension->set_source(source);
extension->set_client_version(client_version);
if (emitter_version != kEmptyEmitterVersion)
extension->set_emitter_version(emitter_version);

auto* compiler = extension->mutable_flags()->mutable_compiler();
compiler->set_version(compiler_version);
extension->mutable_flags()->set_action(action);
Expand Down Expand Up @@ -377,14 +383,15 @@ TEST_F(AbsorberTest, BadMessageStatus) {
<< "Daemon must not store references to the connection";
}

TEST_F(AbsorberTest, BadClientVersion) {
TEST_F(AbsorberTest, BadEmitterVersion) {
const String expected_host = "fake_host";
const ui16 expected_port = 12345;
const String compiler_version("compiler_version");
const String compiler_path("compiler_path");

conf.mutable_absorber()->mutable_local()->set_host(expected_host);
conf.mutable_absorber()->mutable_local()->set_port(expected_port);
conf.mutable_absorber()->set_min_emitter_version(kGoodEmitterVersion);
auto* version = conf.add_versions();
version->set_version(compiler_version);
version->set_path(compiler_path);
Expand All @@ -399,7 +406,7 @@ TEST_F(AbsorberTest, BadClientVersion) {
connection->CallOnSend([](const net::Connection::Message& message) {
EXPECT_TRUE(message.HasExtension(net::proto::Status::extension));
const auto& status = message.GetExtension(net::proto::Status::extension);
EXPECT_EQ(net::proto::Status::BAD_CLIENT_VERSION, status.code());
EXPECT_EQ(net::proto::Status::BAD_EMITTER_VERSION, status.code());

EXPECT_FALSE(message.HasExtension(proto::Result::extension));
});
Expand All @@ -413,7 +420,7 @@ TEST_F(AbsorberTest, BadClientVersion) {
SharedPtr<net::TestConnection> test_connection =
std::static_pointer_cast<net::TestConnection>(connection1);

auto message(CreateMessage(""_l, ""_l, ""_l, ""_l, 1));
auto message(CreateMessage(""_l, ""_l, ""_l, ""_l, kBadEmitterVersion));
EXPECT_TRUE(
test_connection->TriggerReadAsync(std::move(message), StatusOK()));

Expand All @@ -437,7 +444,9 @@ TEST_F(AbsorberTest, BadClientVersion) {
});
auto message(CreateMessage("source"_l, "action"_l, compiler_version));
auto* extension = message->MutableExtension(proto::Remote::extension);
extension->clear_client_version();

// Force to use default value from .proto file
extension->clear_emitter_version();
EXPECT_TRUE(
test_connection->TriggerReadAsync(std::move(message), StatusOK()));

Expand All @@ -460,5 +469,62 @@ TEST_F(AbsorberTest, BadClientVersion) {
<< "Daemon must not store references to the connection";
}

TEST_F(AbsorberTest, GoodCustomEmitterVersion) {
const String expected_host = "fake_host";
const ui16 expected_port = 12345;
const String compiler_version("compiler_version");
const String compiler_path("compiler_path");
const ui32 custom_emitter_version = kGoodEmitterVersion + 1000;

conf.mutable_absorber()->mutable_local()->set_host(expected_host);
conf.mutable_absorber()->mutable_local()->set_port(expected_port);
conf.mutable_absorber()->set_min_emitter_version(custom_emitter_version);
auto* version = conf.add_versions();
version->set_version(compiler_version);
version->set_path(compiler_path);

listen_callback =
[&expected_host, expected_port](const String& host, ui16 port, String*) {
EXPECT_EQ(expected_host, host);
EXPECT_EQ(expected_port, port);
return true;
};
connect_callback = [](net::TestConnection* connection) {
connection->CallOnSend([](const net::Connection::Message& message) {
EXPECT_TRUE(message.HasExtension(net::proto::Status::extension));
const auto& status = message.GetExtension(net::proto::Status::extension);
EXPECT_EQ(net::proto::Status::OK, status.code());

EXPECT_TRUE(message.HasExtension(proto::Result::extension));
EXPECT_TRUE(message.GetExtension(proto::Result::extension).has_obj());
});
};

absorber.reset(new Absorber(conf));
ASSERT_TRUE(absorber->Initialize());

auto connection = test_service->TriggerListen(expected_host, expected_port);
{
SharedPtr<net::TestConnection> test_connection =
std::static_pointer_cast<net::TestConnection>(connection);

auto message(CreateMessage("source"_l, "action"_l, compiler_version, ""_l,
custom_emitter_version));
EXPECT_TRUE(
test_connection->TriggerReadAsync(std::move(message), StatusOK()));

absorber.reset();
}

EXPECT_EQ(1u, run_count);
EXPECT_EQ(1u, listen_count);
EXPECT_EQ(1u, connect_count);
EXPECT_EQ(1u, connections_created);
EXPECT_EQ(1u, read_count);
EXPECT_EQ(1u, send_count);
EXPECT_EQ(1, connection.use_count())
<< "Daemon must not store references to the connection";
}

} // namespace daemon
} // namespace dist_clang
3 changes: 2 additions & 1 deletion src/daemon/configuration.proto
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,8 @@ message Configuration {
}

message Absorber {
required Host local = 1;
required Host local = 1;
optional uint32 min_emitter_version = 2 [ default = 100 ];
}

message Collector {
Expand Down
6 changes: 3 additions & 3 deletions src/daemon/remote.proto
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ package dist_clang.daemon.proto;

// Sent from emitter to absorber.
message Remote {
optional base.proto.Flags flags = 1;
optional string source = 2;
optional uint32 client_version = 3 [ default = 100 ];
optional base.proto.Flags flags = 1;
optional string source = 2;
optional uint32 emitter_version = 3 [ default = 100 ];

extend net.proto.Universal {
optional Remote extension = 6;
Expand Down
19 changes: 10 additions & 9 deletions src/net/universal.proto
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,15 @@ message Universal {

message Status {
enum Code {
OK = 0;
INCONSEQUENT = 1;
NETWORK = 2;
BAD_MESSAGE = 3;
EMPTY_MESSAGE = 4;
EXECUTION = 5;
OVERLOAD = 6;
NO_VERSION = 7;
BAD_CLIENT_VERSION = 8;
OK = 0;
INCONSEQUENT = 1;
NETWORK = 2;
BAD_MESSAGE = 3;
EMPTY_MESSAGE = 4;
EXECUTION = 5;
OVERLOAD = 6;
NO_VERSION = 7;
BAD_EMITTER_VERSION = 8;
}

required Code code = 1 [ default = OK ];
Expand All @@ -29,3 +29,4 @@ message Status {
}

// Last unused extension index: 8.

0 comments on commit 89dee14

Please sign in to comment.