blob: e05ce0323e032911d46d8682661ffe4463fdc276 [file] [log] [blame]
// 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.
#ifndef __TEST_CONTAINERIZER_HPP__
#define __TEST_CONTAINERIZER_HPP__
#ifndef __WINDOWS__
#include <unistd.h>
#endif // __WINDOWS__
#include <map>
#include <memory>
#include <string>
#include <mesos/executor.hpp>
#include <mesos/mesos.hpp>
#include <mesos/resources.hpp>
#include <mesos/type_utils.hpp>
#include <mesos/v1/executor.hpp>
#include <process/dispatch.hpp>
#include <process/future.hpp>
#include <process/gmock.hpp>
#include <process/http.hpp>
#include <process/pid.hpp>
#include <stout/hashmap.hpp>
#include <stout/os.hpp>
#include <stout/try.hpp>
#include <stout/uuid.hpp>
#include "slave/containerizer/containerizer.hpp"
#include "slave/slave.hpp"
#include "slave/state.hpp"
#include "tests/mesos.hpp"
namespace mesos {
namespace internal {
namespace tests {
// Forward declaration.
class MockExecutor;
class TestContainerizerProcess;
class TestContainerizer : public slave::Containerizer
{
public:
// TODO(bmahler): These constructors assume that ExecutorIDs are
// unique across FrameworkIDs, which is not the case.
TestContainerizer(
const ExecutorID& executorId,
const std::shared_ptr<v1::MockHTTPExecutor>& executor);
TestContainerizer(const hashmap<ExecutorID, Executor*>& executors);
TestContainerizer(const ExecutorID& executorId, Executor* executor);
explicit TestContainerizer(MockExecutor* executor);
TestContainerizer();
~TestContainerizer() override;
process::Future<hashset<ContainerID>> containers() override;
MOCK_METHOD1(
recover,
process::Future<Nothing>(const Option<slave::state::SlaveState>&));
MOCK_METHOD4(
launch,
process::Future<slave::Containerizer::LaunchResult>(
const ContainerID&,
const mesos::slave::ContainerConfig&,
const std::map<std::string, std::string>&,
const Option<std::string>&));
MOCK_METHOD1(
attach,
process::Future<process::http::Connection>(
const ContainerID& containerId));
MOCK_METHOD2(
update,
process::Future<Nothing>(const ContainerID&, const Resources&));
MOCK_METHOD1(
usage,
process::Future<ResourceStatistics>(const ContainerID&));
MOCK_METHOD1(
status,
process::Future<ContainerStatus>(const ContainerID&));
MOCK_METHOD1(
wait,
process::Future<Option<mesos::slave::ContainerTermination>>(
const ContainerID&));
MOCK_METHOD1(
destroy,
process::Future<Option<mesos::slave::ContainerTermination>>(
const ContainerID&));
MOCK_METHOD2(
kill,
process::Future<bool>(const ContainerID&, int));
MOCK_METHOD1(
pruneImages,
process::Future<Nothing>(const std::vector<Image>&));
// Additional destroy method for testing because we won't know the
// ContainerID created for each container.
process::Future<Option<mesos::slave::ContainerTermination>> destroy(
const FrameworkID& frameworkId,
const ExecutorID& executorId);
private:
void setup();
// The following functions act as a level of indirection to
// perform the dispatch while still allowing the above to be
// mock functions.
process::Future<Nothing> _recover(
const Option<slave::state::SlaveState>& state);
process::Future<slave::Containerizer::LaunchResult> _launch(
const ContainerID& containerId,
const mesos::slave::ContainerConfig& containerConfig,
const std::map<std::string, std::string>& environment,
const Option<std::string>& pidCheckpointPath);
process::Future<process::http::Connection> _attach(
const ContainerID& containerId);
process::Future<Nothing> _update(
const ContainerID& containerId,
const Resources& resources);
process::Future<ResourceStatistics> _usage(
const ContainerID& containerId);
process::Future<ContainerStatus> _status(
const ContainerID& containerId);
process::Future<Option<mesos::slave::ContainerTermination>> _wait(
const ContainerID& containerId);
process::Future<Option<mesos::slave::ContainerTermination>> _destroy(
const ContainerID& containerId);
process::Future<bool> _kill(
const ContainerID& containerId,
int status);
process::Future<Nothing> _pruneImages(
const std::vector<Image>& excludedImages);
process::Owned<TestContainerizerProcess> process;
};
} // namespace tests {
} // namespace internal {
} // namespace mesos {
#endif // __TEST_CONTAINERIZER_HPP__