aboutsummaryrefslogtreecommitdiff
path: root/nixpkgs/nixos/tests/mesos_test.py
blob: be8bb32e49a7eea65b3d770567773db88e4b43d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/usr/bin/env python
import uuid
import time
import subprocess
import os

import sys

from mesos.interface import Scheduler
from mesos.native import MesosSchedulerDriver
from mesos.interface import mesos_pb2

def log(msg):
    process = subprocess.Popen("systemd-cat", stdin=subprocess.PIPE)
    (out,err) = process.communicate(msg)

class NixosTestScheduler(Scheduler):
    def __init__(self):
        self.master_ip = sys.argv[1]
        self.download_uri = sys.argv[2]

    def resourceOffers(self, driver, offers):
        log("XXX got resource offer")

        offer = offers[0]
        task = self.new_task(offer)
        uri = task.command.uris.add()
        uri.value = self.download_uri
        task.command.value = "cat test.result"
        driver.launchTasks(offer.id, [task])

    def statusUpdate(self, driver, update):
        log("XXX status update")
        if update.state == mesos_pb2.TASK_FAILED:
            log("XXX test task failed with message: " + update.message)
            driver.stop()
            sys.exit(1)
        elif update.state == mesos_pb2.TASK_FINISHED:
            driver.stop()
            sys.exit(0)

    def new_task(self, offer):
        task = mesos_pb2.TaskInfo()
        id = uuid.uuid4()
        task.task_id.value = str(id)
        task.slave_id.value = offer.slave_id.value
        task.name = "task {}".format(str(id))

        cpus = task.resources.add()
        cpus.name = "cpus"
        cpus.type = mesos_pb2.Value.SCALAR
        cpus.scalar.value = 0.1

        mem = task.resources.add()
        mem.name = "mem"
        mem.type = mesos_pb2.Value.SCALAR
        mem.scalar.value = 32

        return task

if __name__ == '__main__':
    log("XXX framework started")

    framework = mesos_pb2.FrameworkInfo()
    framework.user = "root"
    framework.name = "nixos-test-framework"
    driver = MesosSchedulerDriver(
        NixosTestScheduler(),
        framework,
        sys.argv[1] + ":5050"
    )
    driver.run()