Mercurial > treepkg
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")