David Rochberg | 7c79a81 | 2011-01-19 19:24:45 | [diff] [blame] | 1 | #!/usr/bin/python |
| 2 | |
| 3 | # Copyright (c) 2011 The Chromium OS Authors. All rights reserved. |
| 4 | # Use of this source code is governed by a BSD-style license that can be |
| 5 | # found in the LICENSE file. |
| 6 | |
| 7 | """Unit tests for gmerge.""" |
| 8 | |
Chris Sosa | 37b217a | 2011-04-13 21:03:51 | [diff] [blame] | 9 | import os |
David Rochberg | 7c79a81 | 2011-01-19 19:24:45 | [diff] [blame] | 10 | import unittest |
| 11 | |
Gilad Arnold | abb352e | 2012-09-23 08:24:27 | [diff] [blame] | 12 | import gmerge |
| 13 | |
| 14 | |
David Rochberg | 7c79a81 | 2011-01-19 19:24:45 | [diff] [blame] | 15 | class Flags(object): |
| 16 | def __init__(self, dictionary): |
| 17 | self.__dict__.update(dictionary) |
| 18 | |
| 19 | |
| 20 | class GMergeTest(unittest.TestCase): |
| 21 | """Test for gmerge.""" |
| 22 | |
| 23 | def setUp(self): |
| 24 | self.lsb_release_lines = [ |
| 25 | 'CHROMEOS_RELEASE_BOARD=x86-mario\r\n', |
| 26 | 'CHROMEOS_DEVSERVER=http://localhost:8080/\n'] |
| 27 | |
| 28 | def testLsbRelease(self): |
| 29 | merger = gmerge.GMerger(self.lsb_release_lines) |
| 30 | self.assertEqual({'CHROMEOS_RELEASE_BOARD': 'x86-mario', |
| 31 | 'CHROMEOS_DEVSERVER': 'http://localhost:8080/'}, |
| 32 | merger.lsb_release) |
| 33 | |
| 34 | def testPostData(self): |
Chris Sosa | e66c265 | 2011-04-13 21:55:25 | [diff] [blame] | 35 | old_env = os.environ |
| 36 | os.environ = {} |
Chris Sosa | 37b217a | 2011-04-13 21:03:51 | [diff] [blame] | 37 | os.environ['USE'] = 'a b c d +e' |
David James | bf0db10 | 2011-06-02 20:06:38 | [diff] [blame] | 38 | gmerge.FLAGS = Flags({'accept_stable': 'blah', |
| 39 | 'deep': False, |
| 40 | 'usepkg': False}) |
David Rochberg | 7c79a81 | 2011-01-19 19:24:45 | [diff] [blame] | 41 | |
| 42 | merger = gmerge.GMerger(self.lsb_release_lines) |
| 43 | self.assertEqual( |
David James | bf0db10 | 2011-06-02 20:06:38 | [diff] [blame] | 44 | 'use=a+b+c+d+%2Be&board=x86-mario&deep=&pkg=package_name&usepkg=&' |
| 45 | 'accept_stable=blah', |
David Rochberg | 7c79a81 | 2011-01-19 19:24:45 | [diff] [blame] | 46 | merger.GeneratePackageRequest('package_name')) |
Chris Sosa | e66c265 | 2011-04-13 21:55:25 | [diff] [blame] | 47 | os.environ = old_env |
David Rochberg | 7c79a81 | 2011-01-19 19:24:45 | [diff] [blame] | 48 | |
| 49 | |
| 50 | if __name__ == '__main__': |
| 51 | unittest.main() |