[Checkins] SVN: groktoolkit/trunk/ Add a bootstrap and a buildout to run all the tests (using compattest)

Sylvain Viollon sylvain at infrae.com
Wed Jan 20 07:36:37 EST 2010


Log message for revision 108304:
  Add a bootstrap and a buildout to run all the tests (using compattest)
  

Changed:
  A   groktoolkit/trunk/bootstrap.py
  A   groktoolkit/trunk/buildout.cfg
  U   groktoolkit/trunk/grok.cfg

-=-
Added: groktoolkit/trunk/bootstrap.py
===================================================================
--- groktoolkit/trunk/bootstrap.py	                        (rev 0)
+++ groktoolkit/trunk/bootstrap.py	2010-01-20 12:36:37 UTC (rev 108304)
@@ -0,0 +1,121 @@
+##############################################################################
+#
+# Copyright (c) 2006 Zope Corporation and Contributors.
+# All Rights Reserved.
+#
+# This software is subject to the provisions of the Zope Public License,
+# Version 2.1 (ZPL).  A copy of the ZPL should accompany this distribution.
+# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
+# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
+# FOR A PARTICULAR PURPOSE.
+#
+##############################################################################
+"""Bootstrap a buildout-based project
+
+Simply run this script in a directory containing a buildout.cfg.
+The script accepts buildout command-line options, so you can
+use the -c option to specify an alternate configuration file.
+
+$Id$
+"""
+
+import os, shutil, sys, tempfile, urllib2
+from optparse import OptionParser
+
+tmpeggs = tempfile.mkdtemp()
+
+is_jython = sys.platform.startswith('java')
+
+# parsing arguments
+parser = OptionParser()
+parser.add_option("-v", "--version", dest="version",
+                          help="use a specific zc.buildout version")
+parser.add_option("-d", "--distribute",
+                   action="store_true", dest="distribute", default=False,
+                   help="Use Disribute rather than Setuptools.")
+
+parser.add_option("-c", None, action="store", dest="config_file",
+                   help=("Specify the path to the buildout configuration "
+                         "file to be used."))
+
+options, args = parser.parse_args()
+
+# if -c was provided, we push it back into args for buildout' main function
+if options.config_file is not None:
+    args += ['-c', options.config_file]
+
+if options.version is not None:
+    VERSION = '==%s' % options.version
+else:
+    VERSION = ''
+
+USE_DISTRIBUTE = options.distribute
+args = args + ['bootstrap']
+
+to_reload = False
+try:
+    import pkg_resources
+    if not hasattr(pkg_resources, '_distribute'):
+        to_reload = True
+        raise ImportError
+except ImportError:
+    ez = {}
+    if USE_DISTRIBUTE:
+        exec urllib2.urlopen('http://python-distribute.org/distribute_setup.py'
+                         ).read() in ez
+        ez['use_setuptools'](to_dir=tmpeggs, download_delay=0, no_fake=True)
+    else:
+        exec urllib2.urlopen('http://peak.telecommunity.com/dist/ez_setup.py'
+                             ).read() in ez
+        ez['use_setuptools'](to_dir=tmpeggs, download_delay=0)
+
+    if to_reload:
+        reload(pkg_resources)
+    else:
+        import pkg_resources
+
+if sys.platform == 'win32':
+    def quote(c):
+        if ' ' in c:
+            return '"%s"' % c # work around spawn lamosity on windows
+        else:
+            return c
+else:
+    def quote (c):
+        return c
+
+cmd = 'from setuptools.command.easy_install import main; main()'
+ws  = pkg_resources.working_set
+
+if USE_DISTRIBUTE:
+    requirement = 'distribute'
+else:
+    requirement = 'setuptools'
+
+if is_jython:
+    import subprocess
+
+    assert subprocess.Popen([sys.executable] + ['-c', quote(cmd), '-mqNxd',
+           quote(tmpeggs), 'zc.buildout' + VERSION],
+           env=dict(os.environ,
+               PYTHONPATH=
+               ws.find(pkg_resources.Requirement.parse(requirement)).location
+               ),
+           ).wait() == 0
+
+else:
+    assert os.spawnle(
+        os.P_WAIT, sys.executable, quote (sys.executable),
+        '-c', quote (cmd), '-mqNxd', quote (tmpeggs), 'zc.buildout' + VERSION,
+        dict(os.environ,
+            PYTHONPATH=
+            ws.find(pkg_resources.Requirement.parse(requirement)).location
+            ),
+        ) == 0
+
+ws.add_entry(tmpeggs)
+ws.require('zc.buildout' + VERSION)
+import zc.buildout.buildout
+zc.buildout.buildout.main(args)
+shutil.rmtree(tmpeggs)

Added: groktoolkit/trunk/buildout.cfg
===================================================================
--- groktoolkit/trunk/buildout.cfg	                        (rev 0)
+++ groktoolkit/trunk/buildout.cfg	2010-01-20 12:36:37 UTC (rev 108304)
@@ -0,0 +1,25 @@
+[buildout]
+parts = test-grok depgraph
+extensions = mr.developer
+extends = grok.cfg
+versions = versions
+allow-picked-versions = false
+#auto-checkout = *
+
+[versions]
+infrae.subversion = 1.4.5
+tl.eggdeps = 0.4
+z3c.recipe.compattest = 0.9
+z3c.recipe.depgraph = 0.5
+mr.developer = 1.9
+
+[test-grok]
+recipe = z3c.recipe.compattest
+include = ${grok:packages}
+
+[depgraph]
+recipe = z3c.recipe.depgraph
+eggs = ${grok:packages}
+extras = True
+variants = base 
+           scc

Modified: groktoolkit/trunk/grok.cfg
===================================================================
--- groktoolkit/trunk/grok.cfg	2010-01-20 12:30:59 UTC (rev 108303)
+++ groktoolkit/trunk/grok.cfg	2010-01-20 12:36:37 UTC (rev 108304)
@@ -1,3 +1,25 @@
+[grok]
+version = 1.1dev
+included =
+   grokcore.annotation
+   grokcore.component
+   grokcore.formlib
+   grokcore.security
+   grokcore.site
+   grokcore.startup
+   grokcore.view
+   grokcore.viewlet
+   grokui.admin
+   martian
+   z3c.autoinclude
+   z3c.evalexception
+   z3c.flashmessage
+   zc.catalog
+
+packages =
+   ${ztk:packages}
+   ${zopeapp:packages}
+
 [buildout]
 extends =
     http://svn.zope.org/*checkout*/zopetoolkit/trunk/zopeapp.cfg?rev=107993



More information about the checkins mailing list