| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #include <gmock/gmock.h> |
| |
| #include <string> |
| |
| #include <process/gmock.hpp> |
| #include <process/pid.hpp> |
| |
| #include "master/flags.hpp" |
| #include "master/master.hpp" |
| #include "tests/mesos.hpp" |
| #include "tests/utils.hpp" |
| |
| using std::map; |
| using std::string; |
| using std::vector; |
| |
| using namespace mesos; |
| using namespace mesos::internal; |
| using namespace mesos::internal::slave; |
| using namespace mesos::internal::tests; |
| |
| using mesos::internal::master::Master; |
| using mesos::internal::slave::Slave; |
| |
| using process::PID; |
| |
| using testing::_; |
| |
| class CredentialsTest : public MesosTest {}; |
| |
| |
| // This test verifies that an authenticated slave is |
| // granted registration by the master. |
| TEST_F(CredentialsTest, authenticatedSlave) |
| { |
| Try<PID<Master> > master = StartMaster(); |
| ASSERT_SOME(master); |
| |
| Future<SlaveRegisteredMessage> slaveRegisteredMessage = |
| FUTURE_PROTOBUF(SlaveRegisteredMessage(), _, _); |
| |
| Try<PID<Slave> > slave = StartSlave(); |
| ASSERT_SOME(slave); |
| |
| AWAIT_READY(slaveRegisteredMessage); |
| ASSERT_NE("", slaveRegisteredMessage.get().slave_id().value()); |
| |
| Shutdown(); |
| } |
| |
| |
| // Test verifing well executed credential authentication |
| // using text formatted credentials so as to test |
| // backwards compatibility |
| TEST_F(CredentialsTest, authenticatedSlaveText) |
| { |
| master::Flags flags = CreateMasterFlags(); |
| |
| const string& path = path::join(os::getcwd(), "credentials"); |
| |
| Try<int> fd = os::open( |
| path, |
| O_WRONLY | O_CREAT | O_TRUNC, |
| S_IRUSR | S_IWUSR | S_IRGRP); |
| |
| CHECK_SOME(fd); |
| |
| const std::string& credentials = |
| DEFAULT_CREDENTIAL.principal() + " " + DEFAULT_CREDENTIAL.secret(); |
| CHECK_SOME(os::write(fd.get(), credentials)) |
| << "Failed to write credentials to '" << path << "'"; |
| CHECK_SOME(os::close(fd.get())); |
| |
| flags.credentials = "file://" + path; |
| |
| Try<PID<Master> > master = StartMaster(flags); |
| ASSERT_SOME(master); |
| |
| Future<SlaveRegisteredMessage> slaveRegisteredMessage = |
| FUTURE_PROTOBUF(SlaveRegisteredMessage(), _, _); |
| |
| slave::Flags slaveFlags = CreateSlaveFlags(); |
| |
| slaveFlags.credential = "file://" + path; |
| |
| Try<PID<Slave> > slave = StartSlave(slaveFlags); |
| ASSERT_SOME(slave); |
| |
| AWAIT_READY(slaveRegisteredMessage); |
| ASSERT_NE("", slaveRegisteredMessage.get().slave_id().value()); |
| |
| Shutdown(); |
| } |