diff options
author | Fred Drake <fdrake@acm.org> | 2004-06-21 16:15:22 (GMT) |
---|---|---|
committer | Fred Drake <fdrake@acm.org> | 2004-06-21 16:15:22 (GMT) |
commit | 2c9f889122b48395c1997b08dd328f33f64f1ecd (patch) | |
tree | 75195716ce859dabaa803b2d7f70425659151b5a /Lib/distutils/tests | |
parent | 9ddf40b4e1f8875a807c026ef04e79f51debbe26 (diff) | |
download | cpython-2c9f889122b48395c1997b08dd328f33f64f1ecd.zip cpython-2c9f889122b48395c1997b08dd328f33f64f1ecd.tar.gz cpython-2c9f889122b48395c1997b08dd328f33f64f1ecd.tar.bz2 |
add a couple of tests for the build_scripts command
Diffstat (limited to 'Lib/distutils/tests')
-rw-r--r-- | Lib/distutils/tests/test_build_scripts.py | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/Lib/distutils/tests/test_build_scripts.py b/Lib/distutils/tests/test_build_scripts.py new file mode 100644 index 0000000..0cfef4e --- /dev/null +++ b/Lib/distutils/tests/test_build_scripts.py @@ -0,0 +1,74 @@ +"""Tests for distutils.command.build_scripts.""" + +import os +import unittest + +from distutils.command.build_scripts import build_scripts +from distutils.core import Distribution + +from distutils.tests import support + + +class BuildScriptsTestCase(support.TempdirManager, unittest.TestCase): + + def test_default_settings(self): + cmd = self.get_build_scripts_cmd("/foo/bar", []) + self.assert_(not cmd.force) + self.assert_(cmd.build_dir is None) + + cmd.finalize_options() + + self.assert_(cmd.force) + self.assertEqual(cmd.build_dir, "/foo/bar") + + def test_build(self): + source = self.mkdtemp() + target = self.mkdtemp() + expected = self.write_sample_scripts(source) + + cmd = self.get_build_scripts_cmd(target, + [os.path.join(source, fn) + for fn in expected]) + cmd.finalize_options() + cmd.run() + + built = os.listdir(target) + for name in expected: + self.assert_(name in built) + + def get_build_scripts_cmd(self, target, scripts): + dist = Distribution() + dist.scripts = scripts + dist.command_obj["build"] = support.DummyCommand( + build_scripts=target, + force=1 + ) + return build_scripts(dist) + + def write_sample_scripts(self, dir): + expected = [] + expected.append("script1.py") + self.write_script(dir, "script1.py", + ("#! /usr/bin/env python2.3\n" + "# bogus script w/ Python sh-bang\n" + "pass\n")) + expected.append("script2.py") + self.write_script(dir, "script2.py", + ("#!/usr/bin/python\n" + "# bogus script w/ Python sh-bang\n" + "pass\n")) + expected.append("shell.sh") + self.write_script(dir, "shell.sh", + ("#!/bin/sh\n" + "# bogus shell script w/ sh-bang\n" + "exit 0\n")) + return expected + + def write_script(self, dir, name, text): + f = open(os.path.join(dir, name), "w") + f.write(text) + f.close() + + +def test_suite(): + return unittest.makeSuite(BuildScriptsTestCase) |