summaryrefslogtreecommitdiff
path: root/doc/build/testdocs.py
diff options
context:
space:
mode:
authorAlexey Shamrin <none@none>2006-03-15 13:39:11 +0000
committerAlexey Shamrin <none@none>2006-03-15 13:39:11 +0000
commit33e30aacc3b69b5d90b32d4d8e16bc9c77c43835 (patch)
tree60eec14ffe8fbda757a3f6b59bb252f8fc006f74 /doc/build/testdocs.py
parent7f98b58c871c690e861c16091b3c507f90b1ddda (diff)
downloadsqlalchemy-33e30aacc3b69b5d90b32d4d8e16bc9c77c43835.tar.gz
Tutorial draft (not finished) and documentation framework improvements
* a first step to a new documentation framework, using Markdown syntax, with some extensions (detailed in txt2myt.py docstrings): * `rel:something` for internal links * `{@name=something}` to override default header names (used when linking) * `{python}` to force code block to use Python syntax highlighting (not needed when using examples with `>>>` prompt) * txt2myt.py -- converter from .txt to .myt * a draft of tutorial.txt, which uses new syntax * testdocs.py -- check examples in documentation using doctest (currently only in tutorial.txt)
Diffstat (limited to 'doc/build/testdocs.py')
-rw-r--r--doc/build/testdocs.py49
1 files changed, 49 insertions, 0 deletions
diff --git a/doc/build/testdocs.py b/doc/build/testdocs.py
new file mode 100644
index 000000000..8394acf1e
--- /dev/null
+++ b/doc/build/testdocs.py
@@ -0,0 +1,49 @@
+import os
+import re
+import doctest
+
+def teststring(s, name, globs=None, verbose=None, report=True,
+ optionflags=0, extraglobs=None, raise_on_error=False,
+ parser=doctest.DocTestParser()):
+
+ from doctest import DebugRunner, DocTestRunner, master
+
+ # Assemble the globals.
+ if globs is None:
+ globs = {}
+ else:
+ globs = globs.copy()
+ if extraglobs is not None:
+ globs.update(extraglobs)
+
+ if raise_on_error:
+ runner = DebugRunner(verbose=verbose, optionflags=optionflags)
+ else:
+ runner = DocTestRunner(verbose=verbose, optionflags=optionflags)
+
+ test = parser.get_doctest(s, globs, name, name, 0)
+ runner.run(test)
+
+ if report:
+ runner.summarize()
+
+ if master is None:
+ master = runner
+ else:
+ master.merge(runner)
+
+ return runner.failures, runner.tries
+
+def replace_file(s, oldfile, newfile):
+ engine = r"(^\s*>>>\s*[a-zA-Z_]\w*\s*=\s*create_engine\('sqlite',\s*\{'filename':\s*')" + oldfile+ "('\}\)$)"
+ engine = re.compile(engine, re.MULTILINE)
+ s, n = re.subn(engine, r'\1' + newfile + r'\2', s, 1)
+ if not n:
+ raise ValueError("Couldn't find suitable create_engine call to replace '%s' in it" % oldfile)
+ return s
+
+filename = 'content/tutorial.txt'
+s = open(filename).read()
+s = replace_file(s, 'tutorial.db', ':memory:')
+teststring(s, filename)
+