view test/test_status.py @ 441:eadcb1bb54e2

Merged revisions 388-399 via svnmerge from svn+ssh://svn.wald.intevation.org/treepkg/branches/treepkg-status ........ r388 | bricks | 2010-07-28 10:38:50 +0200 (Mi, 28 Jul 2010) | 3 lines fix if statement upload hook should be called if it's not empty ........ r389 | bricks | 2010-07-28 13:38:00 +0200 (Mi, 28 Jul 2010) | 2 lines only rsync specified architectures from cachedir to publishdir ........ r390 | bricks | 2010-07-29 14:07:57 +0200 (Do, 29 Jul 2010) | 2 lines introduced after_copy_hook and made rsync upload to publishdir optional ........ r391 | bricks | 2010-07-29 15:43:39 +0200 (Do, 29 Jul 2010) | 3 lines publish package must be default to get original behaviour be more verbose at publishing ........ r392 | bricks | 2010-07-29 16:50:53 +0200 (Do, 29 Jul 2010) | 2 lines fix handling of showing only successfull builds together with num packages ........ r393 | bricks | 2010-07-29 16:52:42 +0200 (Do, 29 Jul 2010) | 2 lines fixed typo ........ r394 | bricks | 2010-07-29 16:59:10 +0200 (Do, 29 Jul 2010) | 2 lines fixed another typo ........ r395 | bricks | 2010-07-29 18:05:54 +0200 (Do, 29 Jul 2010) | 3 lines fixed another typo treepkg is really slow with many revisions ........ r396 | bricks | 2010-08-02 12:41:55 +0200 (Mo, 02 Aug 2010) | 2 lines fixed typos ........ r397 | bricks | 2010-08-02 17:36:12 +0200 (Mo, 02 Aug 2010) | 3 lines be more error prone in listing different files not checking if a dir exists caused several errors if a build wasn't successful ........ r398 | bricks | 2010-08-05 18:21:47 +0200 (Do, 05 Aug 2010) | 2 lines review changes ........ r399 | bricks | 2010-08-06 13:06:08 +0200 (Fr, 06 Aug 2010) | 4 lines cleanup modules fix test_info testcases added testcases for remove_trailingslashes and expand_filename ........
author Bjoern Ricks <bricks@intevation.de>
date Fri, 06 Aug 2010 13:41:54 +0000
parents 27824d3add92
children
line wrap: on
line source
# Copyright (C) 2007, 2008, 2009 by Intevation GmbH
# Authors:
# Bernhard Herzog <bh@intevation.de>
#
# This program is free software under the GPL (>=v2)
# Read the file COPYING coming with the software for details.

"""Tests for the Status classes"""

import os
import stat
import unittest
from datetime import datetime

from treepkg.status import RevisionStatus, Status, EnumFieldDesc, \
     StringFieldDesc, DateFieldDesc
from treepkg.util import writefile

from filesupport import FileTestMixin



class TestStatus(unittest.TestCase, FileTestMixin):

    def setUp(self):
        self.filename = self.temp_file_name("status")
        if os.path.exists(self.filename):
            os.remove(self.filename)

    def test_status(self):
        status = RevisionStatus(self.filename)
        status.error()

        otherstatus = RevisionStatus(self.filename)
        self.assertEquals(otherstatus.status.name, "error")

    def test_status_file_permissions(self):
        status = RevisionStatus(self.filename)
        status.error()

        mode = os.stat(self.filename).st_mode
        self.assertEquals(stat.S_IMODE(mode) & 0444, 0444)

    def test_getting_unknown_fields(self):
        status = RevisionStatus(self.filename)
        self.assertRaises(AttributeError, getattr, status, "unknown_field")

    def test_setting_unknown_fields(self):
        status = RevisionStatus(self.filename)
        self.assertRaises(AttributeError,
                          setattr, status, "unknown_field", "some value")

    def test_default_values(self):
        status = RevisionStatus(self.filename)
        self.assertEquals(status.status.name, "unknown")
        self.assertEquals(status.start, None)
        self.assertEquals(status.stop, None)
        self.assertEquals(status.tags, "")

    def test_date(self):
        timestamp = datetime(2007, 3, 9, 17, 32, 55)
        status = RevisionStatus(self.filename)
        status.start = timestamp

        otherstatus = RevisionStatus(self.filename)
        self.assertEquals(otherstatus.start, timestamp)

    def test_magic(self):
        writefile(self.filename,
                  "Some other magic\nstart: 2007-03-09 17:32:55\n")
        self.assertRaises(ValueError, RevisionStatus, self.filename)

    def test_status_enum(self):

        class TestStatus(Status):
            status = EnumFieldDesc()
            status.add("not_running", "Process is not running",
                       default=True)
            status.add("running", "Process is running")
            status.add("error", "An error occurred")

        status = TestStatus(self.filename)
        status.running()

        otherstatus = TestStatus(self.filename)
        self.assertEquals(otherstatus.status.name, "running")

    def test_serialize(self):
        class TestStatus(Status):
            _magic = "TestStatus 1.0\n"

            status = EnumFieldDesc()
            status.add("not_running", "Process is not running",
                       default=True)
            status.add("running", "Process is running")
            status.add("error", "An error occurred")

            start = DateFieldDesc(default=None)

            name = StringFieldDesc(default="fred")

        status = TestStatus(None)
        status.running()
        status.start = datetime(2007, 3, 9, 17, 32, 55)
        status.name = "Dave"

        self.assertEquals(sorted(status.serialize()),
                          ["TestStatus 1.0\n",
                           "name: Dave\n",
                           "start: 2007-03-09 17:32:55\n",
                           "status: running\n"])

    def test_deserialize(self):
        class TestStatus(Status):
            _magic = "TestStatus 1.0\n"

            status = EnumFieldDesc()
            status.add("not_running", "Process is not running",
                       default=True)
            status.add("running", "Process is running")
            status.add("error", "An error occurred")

            start = DateFieldDesc(default=None)

            name = StringFieldDesc(default="fred")

        status = TestStatus(None)
        status.deserialize(iter(["TestStatus 1.0\n",
                                 "name: Dave\n",
                                 "start: 2007-03-09 17:32:55\n",
                                 "status: running\n"]))
        self.assertEquals(status.status.name, "running")
        self.assertEquals(status.start, datetime(2007, 3, 9, 17, 32, 55))
        self.assertEquals(status.name, "Dave")
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)