Exemplo n.º 1
0
    def test_string_representation(self):
        """Tests printable representation of BashJobs."""
        self.assertEqual('BashJob(cmd=ls -l)',
                         BashJob(['ls', '-l']).__repr__(),
                         'BashJob representation not as expected')

        self.assertEqual('BashJob(cmd=pwd)',
                         BashJob(['pwd']).__repr__(),
                         'BashJob representation not as expected')
Exemplo n.º 2
0
    def test_string_representation(self):
        """Tests printable representation of BashJobs."""
        self.assertEqual(
            "BashJob(cmd=ls -l)",
            BashJob(["ls", "-l"]).__repr__(),
            "BashJob representation not as expected",
        )

        self.assertEqual(
            "BashJob(cmd=pwd)",
            BashJob(["pwd"]).__repr__(),
            "BashJob representation not as expected",
        )
Exemplo n.º 3
0
    def test_add_stages(self):
        """Validates the flow created due to submission of jobs to pipeline."""
        def dummy():
            pass

        j1 = Job(dummy)
        b1 = BashJob(["ls"])
        p = Pipe("test")

        # Validate a new pipe contains no jobs by default.
        self.assertEqual([], list(p.job_map.values()))

        # Validate empty job list does nothing but doesn't throw an error
        # either.
        p.add_stage()
        self.assertEqual([], list(p.job_map.values()))

        # Validate the structure of the jobs submittted.
        p.add_stage(j1)
        p.add_stage(b1)
        p.add_stage(b1)
        p.add_stage(j1)
        # Builder pattern
        p.add_stage(j1, b1).add_stage(b1, j1)

        expected = [[j1], [b1], [b1], [j1], [j1, b1], [b1, j1]]

        for (a, b) in zip(p.job_map.values(), expected):
            self.assertEqual(
                a, b, "Jobset in the current stage of pipeline is different")
Exemplo n.º 4
0
    def test_validation(self):
        """Tests the validation of job list submitted to Pipe object."""
        def dummy():
            pass

        job = Job(dummy)
        bashjob = BashJob(["ls"])
        pipe = Pipe("dummy")

        try:
            # Validate job object list is valid list to submit.
            Pipe._validate([job])
            # Validate bash job object list is valid list to submit.
            Pipe._validate([bashjob])
            # Validate pipe object list is valid list to submit.
            Pipe._validate([pipe])
            # Validate lists including both are valid list to submit.
            Pipe._validate([job, bashjob, pipe])
        except AssertionError:
            self.fail("Submit validation raised AssertionError unexpectedly!")

        # Validate wrong types of input raise AssertionError.
        with self.assertRaises(AssertionError):
            Pipe._validate([1])
        with self.assertRaises(AssertionError):
            Pipe._validate(["test_string"])
Exemplo n.º 5
0
    def test_graph(self):
        """Validates graph call on pipelines."""
        p = Pipe("test")

        # Validate graph call on empty pipe.
        try:
            p.graph()
        except Exception:
            self.fail("graph() on empty pipe should not throw any exception")

        # Validate graph on a pipe with jobs.

        def dummy():
            pass

        def dummy1():
            pass

        p1 = Pipe("test1")
        p1.add_jobs([Job(dummy)])
        p1.add_jobs([Job(dummy), Job(dummy1)], run_in_parallel=True)
        p.add_jobs([p1])
        p.add_jobs([Job(dummy), Job(dummy1)], run_in_parallel=True)
        p.add_jobs([BashJob(["ls"])])

        try:
            p.graph()
        except Exception:
            self.fail("graph() should not throw any exception")
Exemplo n.º 6
0
    def test_basic_flow(self):
        """Validates the flow created due to submission of jobs to pipeline."""
        def dummy():
            pass

        j1 = Job(dummy)
        b1 = BashJob(['ls'])
        p = Pipe('test')

        # Validate a new pipe contains no jobs by default.
        self.assertEqual([], list(p.job_map.values()))

        # Validate empty job list does nothing but doesn't throw an error
        # either.
        p.add_jobs([])
        self.assertEqual([], list(p.job_map.values()))

        # Validate the structure of the jobs submittted.
        p.add_jobs([j1, b1])
        p.add_jobs([b1, j1])
        p.add_jobs([j1, b1], True)
        p.add_jobs([b1, j1], True)

        expected = [[j1], [b1], [b1], [j1], [j1, b1], [b1, j1]]

        for (a, b) in zip(p.job_map.values(), expected):
            self.assertEqual(
                a, b, 'Jobset in the current stage of pipeline is different')
Exemplo n.º 7
0
    def test_run(self):
        """Validates run call on pipelines."""
        p = Pipe("test")

        # Validate run call on empty pipe.
        try:
            p.run()
        except Exception:
            self.fail("run() on empty pipe should not throw any exception")

        def dummy():
            pass

        p.add_jobs([Job(dummy), BashJob(["pwd"])])

        try:
            p.run()
        except Exception:
            self.fail("run() should not throw any exception")
Exemplo n.º 8
0
    def test_create_thread_for(self):
        """Tests creation of threads for various jobs."""

        # Validate thread creation for python callable.
        def dummy(msg):
            pass

        t = Pipe._create_thread_for(Job(dummy, args=('a', )))
        self.assertEqual(type(t), Thread,
                         'Thread for Job created successfully')

        # Validate thread creation for Pipe object.
        p = Pipe('test')
        t = Pipe._create_thread_for(p)
        self.assertEqual(type(t), Thread,
                         'Thread for Pipe created successfully')

        # Validate thread creation for bash job.
        t = Pipe._create_thread_for(BashJob(['ls']))
        self.assertEqual(type(t), Thread,
                         'Thread for BashJob created successfully')
Exemplo n.º 9
0
    Job(print_job, ('p2 3.1', )),
    Job(print_job, ('p2 3.2', )),
],
            run_in_parallel=True)
p2.add_jobs([
    Job(print_job, ('p2 4', )),
])

# Create pipeline p1
p1 = Pipe('p1')
p1.add_jobs([
    Job(print_job, ('p1 1', )),
])
p1.add_jobs([
    Job(print_job, ('p1 2.1', )),
    p2,
], run_in_parallel=True)

# Create pipeline p
p = Pipe('p')
p.add_jobs(
    [Job(print_job, ('p 1', )), p1,
     BashJob(['ls', '-l']),
     BashJob(['pwd'])])

# Display the structure of the pipeline to be run.
p.graph()

# Run the pipeline.
p.run()
Exemplo n.º 10
0
 def test_equality(self):
     """Validates equality of bash jobs."""
     self.assertEqual(BashJob(['ls']), BashJob(['ls']))
     self.assertEqual(BashJob(['ls -l']), BashJob(['ls -l']))
     self.assertNotEqual(BashJob(['pwd']), BashJob(['ls']))
Exemplo n.º 11
0
# Create pipeline p
# When created as Pipe("p") or Pipe("p", Gate.FAIL_FAST) the pipeline exits the
# execution in the first stage where it encounters exception.
#
# When created as Pipe("p", Gate.EXECUTE_ALL) the pipeline is forgiving of
# exceptions and continues to execute all jobs even if an exception is thrwon
# in a stage.
#
# Note that when an external dependency is added to the Pipeline, as showin in
# line 93, the pipeline is not executed unless all of the pipelines are
# mentioned as dependencies are successfully executed.

# Create pipeline p3
p3 = Pipe("p3")
p3.add_jobs([BashJob(["ls"])])
p3.add_dependency(p1, p2)

p = Pipe("p")
p.add_jobs([
    Job(print_job, ("p 1", )), p1,
    BashJob(["ls", "-l"]),
    BashJob(["pwd"]), p3
])

# Display the structure of the pipeline to be run.
p.graph()

# Run the pipeline.
p.run()
Exemplo n.º 12
0
 def test_equality(self):
     """Validates equality of bash jobs."""
     self.assertEqual(BashJob(["ls"]), BashJob(["ls"]))
     self.assertEqual(BashJob(["ls -l"]), BashJob(["ls -l"]))
     self.assertNotEqual(BashJob(["pwd"]), BashJob(["ls"]))