예제 #1
0
  def test_scheduler_metrics(self):
    scheduler_key = gen_encryption_key()

    scheduler = MysosScheduler(
        self._state,
        self._state_provider,
        self._framework_user,
        "./executor.pex",
        "cmd.sh",
        self._zk_client,
        self._zk_url,
        Amount(5, Time.SECONDS),
        "/etc/mysos/admin_keyfile.yml",
        scheduler_key)

    RootMetrics().register_observable('scheduler', scheduler)

    scheduler.registered(self._driver, self._framework_id, object())

    sample = RootMetrics().sample()
    assert sample['scheduler.framework_registered'] == 1

    scheduler.create_cluster(
        "cluster1", "mysql_user", 3, cluster_password='******')

    sample = RootMetrics().sample()
    assert sample['scheduler.cluster_count'] == 1
    assert sample['scheduler.total_requested_mem_mb'] == DEFAULT_TASK_MEM.as_(Data.MB) * 3
    assert sample['scheduler.total_requested_disk_mb'] == DEFAULT_TASK_DISK.as_(Data.MB) * 3
    assert sample['scheduler.total_requested_cpus'] == DEFAULT_TASK_CPUS * 3

    scheduler.resourceOffers(self._driver, [self._offer])
    sample = RootMetrics().sample()
    assert sample['scheduler.resource_offers'] == 1
    assert sample['scheduler.tasks_launched'] == 1

    status = mesos_pb2.TaskStatus()
    status.state = mesos_pb2.TASK_RUNNING
    status.slave_id.value = self._offer.slave_id.value
    status.task_id.value = 'mysos-cluster1-0'

    scheduler.statusUpdate(self._driver, status)

    status.state = mesos_pb2.TASK_FAILED
    scheduler.statusUpdate(self._driver, status)

    sample = RootMetrics().sample()
    assert sample['scheduler.tasks_failed'] == 1

    scheduler.delete_cluster("cluster1", 'test_password')

    sample = RootMetrics().sample()
    assert sample['scheduler.cluster_count'] == 0
    assert sample['scheduler.total_requested_mem_mb'] == 0
    assert sample['scheduler.total_requested_disk_mb'] == 0
    assert sample['scheduler.total_requested_cpus'] == 0
예제 #2
0
    def test_scheduler_delete_empty_cluster(self):
        scheduler_key = gen_encryption_key()

        scheduler = MysosScheduler(self._state, self._state_provider,
                                   self._framework_user, "./executor.pex",
                                   "cmd.sh", self._zk_client, self._zk_url,
                                   Amount(5, Time.SECONDS),
                                   "/etc/mysos/admin_keyfile.yml",
                                   scheduler_key)

        scheduler.registered(self._driver, self._framework_id, object())
        _, password = scheduler.create_cluster("cluster1", "mysql_user", 3)

        assert len(scheduler._launchers) == 1

        # Deleting the cluster before any offer comes in for launching any task.
        scheduler.delete_cluster("cluster1", password)

        assert len(scheduler._launchers) == 0
예제 #3
0
    def test_scheduler_metrics(self):
        scheduler_key = gen_encryption_key()

        scheduler = MysosScheduler(self._state, self._state_provider,
                                   self._framework_user, "./executor.pex",
                                   "cmd.sh", self._zk_client, self._zk_url,
                                   Amount(5, Time.SECONDS),
                                   "/etc/mysos/admin_keyfile.yml",
                                   scheduler_key)

        RootMetrics().register_observable('scheduler', scheduler)

        scheduler.registered(self._driver, self._framework_id, object())
        scheduler.create_cluster("cluster1",
                                 "mysql_user",
                                 3,
                                 cluster_password='******')

        sample = RootMetrics().sample()
        assert sample['scheduler.cluster_count'] == 1
        assert sample[
            'scheduler.total_requested_mem_mb'] == DEFAULT_TASK_MEM.as_(
                Data.MB) * 3
        assert sample[
            'scheduler.total_requested_disk_mb'] == DEFAULT_TASK_DISK.as_(
                Data.MB) * 3
        assert sample[
            'scheduler.total_requested_cpus'] == DEFAULT_TASK_CPUS * 3

        scheduler.delete_cluster("cluster1", 'test_password')

        sample = RootMetrics().sample()
        assert sample['scheduler.cluster_count'] == 0
        assert sample['scheduler.total_requested_mem_mb'] == 0
        assert sample['scheduler.total_requested_disk_mb'] == 0
        assert sample['scheduler.total_requested_cpus'] == 0
예제 #4
0
  def test_scheduler_delete_empty_cluster(self):
    scheduler_key = gen_encryption_key()

    scheduler = MysosScheduler(
        self._state,
        self._state_provider,
        self._framework_user,
        "./executor.pex",
        "cmd.sh",
        self._zk_client,
        self._zk_url,
        Amount(5, Time.SECONDS),
        "/etc/mysos/admin_keyfile.yml",
        scheduler_key)

    scheduler.registered(self._driver, self._framework_id, object())
    _, password = scheduler.create_cluster("cluster1", "mysql_user", 3)

    assert len(scheduler._launchers) == 1

    # Deleting the cluster before any offer comes in for launching any task.
    scheduler.delete_cluster("cluster1", password)

    assert len(scheduler._launchers) == 0
def test_scheduler_runs():
  """
    Verifies that the scheduler successfully launches 3 "no-op" MySQL tasks.
    NOTE: Due to the limitation of zake the scheduler's ZK operations are not propagated to
    executors in separate processes but they are unit-tested separately.
  """
  import mesos.native

  # Make sure fake_mysos_executor.pex is available to be fetched by Mesos slave.
  assert os.path.isfile('dist/fake_mysos_executor.pex')

  storage = FakeStorage(SequentialThreadingHandler())
  zk_client = FakeClient(storage=storage)
  zk_client.start()

  zk_url = "zk://fake_host/home/mysos/clusters"
  cluster_name = "test_cluster"
  num_nodes = 3

  state_provider = LocalStateProvider(safe_mkdtemp())

  framework_info = FrameworkInfo(
      user=getpass.getuser(),
      name="mysos",
      checkpoint=False)

  state = Scheduler(framework_info)

  scheduler = MysosScheduler(
      state,
      state_provider,
      getpass.getuser(),
      os.path.abspath("dist/fake_mysos_executor.pex"),
      "./fake_mysos_executor.pex",
      zk_client,
      zk_url,
      Amount(40, Time.SECONDS),
      "/fakepath",
      gen_encryption_key())

  RootMetrics().register_observable('scheduler', scheduler)

  scheduler_driver = mesos.native.MesosSchedulerDriver(
      scheduler,
      framework_info,
      "local")
  scheduler_driver.start()

  # Wait until the scheduler is connected and becomes available.
  assert scheduler.connected.wait(30)

  scheduler.create_cluster(cluster_name, "mysql_user", num_nodes, cluster_password="******")

  # A slave is promoted to be the master.
  deadline(
      lambda: wait_for_master(
          get_cluster_path(posixpath.join(zk_url, 'discover'), cluster_name),
          zk_client),
      Amount(40, Time.SECONDS))

  scheduler.delete_cluster(cluster_name, password="******")

  # The cluster is deleted from ZooKeeper.
  deadline(
      lambda: wait_for_termination(
          get_cluster_path(posixpath.join(zk_url, 'discover'), cluster_name),
          zk_client),
      Amount(40, Time.SECONDS))

  sample = RootMetrics().sample()
  assert sample['scheduler.tasks_killed'] == 1

  assert scheduler_driver.stop() == DRIVER_STOPPED
def test_scheduler_runs():
    """
    Verifies that the scheduler successfully launches 3 "no-op" MySQL tasks.
    NOTE: Due to the limitation of zake the scheduler's ZK operations are not propagated to
    executors in separate processes but they are unit-tested separately.
  """
    import mesos.native

    # Make sure fake_mysos_executor.pex is available to be fetched by Mesos slave.
    assert os.path.isfile('dist/fake_mysos_executor.pex')

    storage = FakeStorage(SequentialThreadingHandler())
    zk_client = FakeClient(storage=storage)
    zk_client.start()

    zk_url = "zk://fake_host/home/mysos/clusters"
    cluster_name = "test_cluster"
    num_nodes = 3

    state_provider = LocalStateProvider(safe_mkdtemp())

    framework_info = FrameworkInfo(user=getpass.getuser(),
                                   name="mysos",
                                   checkpoint=False)

    state = Scheduler(framework_info)

    scheduler = MysosScheduler(state, state_provider, getpass.getuser(),
                               os.path.abspath("dist/fake_mysos_executor.pex"),
                               "./fake_mysos_executor.pex", zk_client, zk_url,
                               Amount(40, Time.SECONDS), "/fakepath",
                               gen_encryption_key())

    RootMetrics().register_observable('scheduler', scheduler)

    scheduler_driver = mesos.native.MesosSchedulerDriver(
        scheduler, framework_info, "local")
    scheduler_driver.start()

    # Wait until the scheduler is connected and becomes available.
    assert scheduler.connected.wait(30)

    scheduler.create_cluster(cluster_name,
                             "mysql_user",
                             num_nodes,
                             cluster_password="******")

    # A slave is promoted to be the master.
    deadline(
        lambda: wait_for_master(
            get_cluster_path(posixpath.join(zk_url, 'discover'), cluster_name),
            zk_client), Amount(40, Time.SECONDS))

    scheduler.delete_cluster(cluster_name, password="******")

    # The cluster is deleted from ZooKeeper.
    deadline(
        lambda: wait_for_termination(
            get_cluster_path(posixpath.join(zk_url, 'discover'), cluster_name),
            zk_client), Amount(40, Time.SECONDS))

    sample = RootMetrics().sample()
    assert sample['scheduler.tasks_killed'] == 1

    assert scheduler_driver.stop() == DRIVER_STOPPED