Initial commit from Paster template
authorAnt Zucaro <azucaro@gmail.com>
Thu, 31 Mar 2011 21:01:30 +0000 (17:01 -0400)
committerAnt Zucaro <azucaro@gmail.com>
Thu, 31 Mar 2011 21:01:30 +0000 (17:01 -0400)
29 files changed:
CHANGES.txt [new file with mode: 0644]
MANIFEST.in [new file with mode: 0644]
README.txt [new file with mode: 0644]
XonStat.egg-info/PKG-INFO [new file with mode: 0644]
XonStat.egg-info/SOURCES.txt [new file with mode: 0644]
XonStat.egg-info/dependency_links.txt [new file with mode: 0644]
XonStat.egg-info/entry_points.txt [new file with mode: 0644]
XonStat.egg-info/not-zip-safe [new file with mode: 0644]
XonStat.egg-info/paster_plugins.txt [new file with mode: 0644]
XonStat.egg-info/requires.txt [new file with mode: 0644]
XonStat.egg-info/top_level.txt [new file with mode: 0644]
development.ini [new file with mode: 0644]
production.ini [new file with mode: 0644]
setup.cfg [new file with mode: 0644]
setup.py [new file with mode: 0644]
xonstat/__init__.py [new file with mode: 0644]
xonstat/models.py [new file with mode: 0644]
xonstat/static/favicon.ico [new file with mode: 0644]
xonstat/static/footerbg.png [new file with mode: 0644]
xonstat/static/headerbg.png [new file with mode: 0644]
xonstat/static/ie6.css [new file with mode: 0644]
xonstat/static/middlebg.png [new file with mode: 0644]
xonstat/static/pylons.css [new file with mode: 0644]
xonstat/static/pyramid-small.png [new file with mode: 0644]
xonstat/static/pyramid.png [new file with mode: 0644]
xonstat/static/transparent.gif [new file with mode: 0644]
xonstat/templates/mytemplate.pt [new file with mode: 0644]
xonstat/tests.py [new file with mode: 0644]
xonstat/views.py [new file with mode: 0644]

diff --git a/CHANGES.txt b/CHANGES.txt
new file mode 100644 (file)
index 0000000..35a34f3
--- /dev/null
@@ -0,0 +1,4 @@
+0.0
+---
+
+-  Initial version
diff --git a/MANIFEST.in b/MANIFEST.in
new file mode 100644 (file)
index 0000000..079d75a
--- /dev/null
@@ -0,0 +1,2 @@
+include *.txt *.ini *.cfg *.rst
+recursive-include xonstat *.ico *.png *.css *.gif *.jpg *.pt *.txt *.mak *.mako *.js *.html *.xml
diff --git a/README.txt b/README.txt
new file mode 100644 (file)
index 0000000..3c11cd3
--- /dev/null
@@ -0,0 +1,4 @@
+XonStat README
+
+
+
diff --git a/XonStat.egg-info/PKG-INFO b/XonStat.egg-info/PKG-INFO
new file mode 100644 (file)
index 0000000..f87db6c
--- /dev/null
@@ -0,0 +1,25 @@
+Metadata-Version: 1.0
+Name: XonStat
+Version: 0.0
+Summary: XonStat
+Home-page: UNKNOWN
+Author: UNKNOWN
+Author-email: UNKNOWN
+License: UNKNOWN
+Description: XonStat README
+        
+        
+        
+        
+        
+        0.0
+        ---
+        
+        -  Initial version
+        
+Keywords: web wsgi bfg pylons pyramid
+Platform: UNKNOWN
+Classifier: Programming Language :: Python
+Classifier: Framework :: Pylons
+Classifier: Topic :: Internet :: WWW/HTTP
+Classifier: Topic :: Internet :: WWW/HTTP :: WSGI :: Application
diff --git a/XonStat.egg-info/SOURCES.txt b/XonStat.egg-info/SOURCES.txt
new file mode 100644 (file)
index 0000000..48b77ff
--- /dev/null
@@ -0,0 +1,29 @@
+CHANGES.txt
+MANIFEST.in
+README.txt
+development.ini
+production.ini
+setup.cfg
+setup.py
+XonStat.egg-info/PKG-INFO
+XonStat.egg-info/SOURCES.txt
+XonStat.egg-info/dependency_links.txt
+XonStat.egg-info/entry_points.txt
+XonStat.egg-info/not-zip-safe
+XonStat.egg-info/paster_plugins.txt
+XonStat.egg-info/requires.txt
+XonStat.egg-info/top_level.txt
+xonstat/__init__.py
+xonstat/models.py
+xonstat/tests.py
+xonstat/views.py
+xonstat/static/favicon.ico
+xonstat/static/footerbg.png
+xonstat/static/headerbg.png
+xonstat/static/ie6.css
+xonstat/static/middlebg.png
+xonstat/static/pylons.css
+xonstat/static/pyramid-small.png
+xonstat/static/pyramid.png
+xonstat/static/transparent.gif
+xonstat/templates/mytemplate.pt
\ No newline at end of file
diff --git a/XonStat.egg-info/dependency_links.txt b/XonStat.egg-info/dependency_links.txt
new file mode 100644 (file)
index 0000000..8b13789
--- /dev/null
@@ -0,0 +1 @@
+
diff --git a/XonStat.egg-info/entry_points.txt b/XonStat.egg-info/entry_points.txt
new file mode 100644 (file)
index 0000000..59d312b
--- /dev/null
@@ -0,0 +1,3 @@
+      [paste.app_factory]
+      main = xonstat:main
+      
\ No newline at end of file
diff --git a/XonStat.egg-info/not-zip-safe b/XonStat.egg-info/not-zip-safe
new file mode 100644 (file)
index 0000000..8b13789
--- /dev/null
@@ -0,0 +1 @@
+
diff --git a/XonStat.egg-info/paster_plugins.txt b/XonStat.egg-info/paster_plugins.txt
new file mode 100644 (file)
index 0000000..d94f7c9
--- /dev/null
@@ -0,0 +1 @@
+pyramid
diff --git a/XonStat.egg-info/requires.txt b/XonStat.egg-info/requires.txt
new file mode 100644 (file)
index 0000000..01d49e4
--- /dev/null
@@ -0,0 +1,6 @@
+pyramid
+SQLAlchemy
+transaction
+repoze.tm2>=1.0b1
+zope.sqlalchemy
+WebError
\ No newline at end of file
diff --git a/XonStat.egg-info/top_level.txt b/XonStat.egg-info/top_level.txt
new file mode 100644 (file)
index 0000000..0e7120e
--- /dev/null
@@ -0,0 +1 @@
+xonstat
diff --git a/development.ini b/development.ini
new file mode 100644 (file)
index 0000000..cd44a59
--- /dev/null
@@ -0,0 +1,68 @@
+[app:XonStat]
+use = egg:XonStat
+reload_templates = true
+debug_authorization = false
+debug_notfound = false
+debug_routematch = false
+debug_templates = true
+default_locale_name = en
+sqlalchemy.url = postgresql+psycopg2://xonstat:xonstat@localhost:5433/xonstatdb
+session.type = file
+session.data_dir = %(here)s/data/sessions/data
+session.lock_dir = %(here)s/data/sessions/lock
+session.key = xonstat
+session.secret = 433fa4b080c2147c79c0ed1cb54e3ce81371fb34
+
+[pipeline:main]
+pipeline =
+    egg:WebError#evalerror
+    tm
+    XonStat
+
+[filter:tm]
+use = egg:repoze.tm2#tm
+commit_veto = repoze.tm:default_commit_veto
+
+[server:main]
+use = egg:Paste#http
+host = 0.0.0.0
+port = 6543
+
+# Begin logging configuration
+
+[loggers]
+keys = root, xonstat, sqlalchemy
+
+[handlers]
+keys = console
+
+[formatters]
+keys = generic
+
+[logger_root]
+level = INFO
+handlers = console
+
+[logger_xonstat]
+level = DEBUG
+handlers =
+qualname = xonstat
+
+[logger_sqlalchemy]
+level = INFO
+handlers =
+qualname = sqlalchemy.engine
+# "level = INFO" logs SQL queries.
+# "level = DEBUG" logs SQL queries and results.
+# "level = WARN" logs neither.  (Recommended for production systems.)
+
+[handler_console]
+class = StreamHandler
+args = (sys.stderr,)
+level = NOTSET
+formatter = generic
+
+[formatter_generic]
+format = %(asctime)s %(levelname)-5.5s [%(name)s][%(threadName)s] %(message)s
+
+# End logging configuration
diff --git a/production.ini b/production.ini
new file mode 100644 (file)
index 0000000..95b9bf6
--- /dev/null
@@ -0,0 +1,77 @@
+[app:XonStat]
+use = egg:XonStat
+reload_templates = false
+debug_authorization = false
+debug_notfound = false
+debug_routematch = false
+debug_templates = false
+default_locale_name = en
+sqlalchemy.url = sqlite:///%(here)s/XonStat.db
+
+[filter:weberror]
+use = egg:WebError#error_catcher
+debug = false
+;error_log = 
+;show_exceptions_in_wsgi_errors = true
+;smtp_server = localhost
+;error_email = janitor@example.com
+;smtp_username = janitor
+;smtp_password = "janitor's password"
+;from_address = paste@localhost
+;error_subject_prefix = "Pyramid Error"
+;smtp_use_tls =
+;error_message =
+
+[filter:tm]
+use = egg:repoze.tm2#tm
+commit_veto = repoze.tm:default_commit_veto
+
+[pipeline:main]
+pipeline =
+    weberror
+    tm
+    XonStat
+
+[server:main]
+use = egg:Paste#http
+host = 0.0.0.0
+port = 6543
+
+# Begin logging configuration
+
+[loggers]
+keys = root, xonstat, sqlalchemy
+
+[handlers]
+keys = console
+
+[formatters]
+keys = generic
+
+[logger_root]
+level = WARN
+handlers = console
+
+[logger_xonstat]
+level = WARN
+handlers =
+qualname = xonstat
+
+[logger_sqlalchemy]
+level = WARN
+handlers =
+qualname = sqlalchemy.engine
+# "level = INFO" logs SQL queries.
+# "level = DEBUG" logs SQL queries and results.
+# "level = WARN" logs neither.  (Recommended for production systems.)
+
+[handler_console]
+class = StreamHandler
+args = (sys.stderr,)
+level = NOTSET
+formatter = generic
+
+[formatter_generic]
+format = %(asctime)s %(levelname)-5.5s [%(name)s][%(threadName)s] %(message)s
+
+# End logging configuration
diff --git a/setup.cfg b/setup.cfg
new file mode 100644 (file)
index 0000000..2bd6b61
--- /dev/null
+++ b/setup.cfg
@@ -0,0 +1,27 @@
+[nosetests]
+match=^test
+nocapture=1
+cover-package=xonstat
+with-coverage=1
+cover-erase=1
+
+[compile_catalog]
+directory = xonstat/locale
+domain = XonStat
+statistics = true
+
+[extract_messages]
+add_comments = TRANSLATORS:
+output_file = xonstat/locale/XonStat.pot
+width = 80
+
+[init_catalog]
+domain = XonStat
+input_file = xonstat/locale/XonStat.pot
+output_dir = xonstat/locale
+
+[update_catalog]
+domain = XonStat
+input_file = xonstat/locale/XonStat.pot
+output_dir = xonstat/locale
+previous = true
diff --git a/setup.py b/setup.py
new file mode 100644 (file)
index 0000000..e167a95
--- /dev/null
+++ b/setup.py
@@ -0,0 +1,47 @@
+import os
+import sys
+
+from setuptools import setup, find_packages
+
+here = os.path.abspath(os.path.dirname(__file__))
+README = open(os.path.join(here, 'README.txt')).read()
+CHANGES = open(os.path.join(here, 'CHANGES.txt')).read()
+
+requires = [
+    'pyramid',
+    'SQLAlchemy',
+    'transaction',
+    'repoze.tm2>=1.0b1', # default_commit_veto
+    'zope.sqlalchemy',
+    'WebError',
+    ]
+
+if sys.version_info[:3] < (2,5,0):
+    requires.append('pysqlite')
+
+setup(name='XonStat',
+      version='0.0',
+      description='XonStat',
+      long_description=README + '\n\n' +  CHANGES,
+      classifiers=[
+        "Programming Language :: Python",
+        "Framework :: Pylons",
+        "Topic :: Internet :: WWW/HTTP",
+        "Topic :: Internet :: WWW/HTTP :: WSGI :: Application",
+        ],
+      author='',
+      author_email='',
+      url='',
+      keywords='web wsgi bfg pylons pyramid',
+      packages=find_packages(),
+      include_package_data=True,
+      zip_safe=False,
+      test_suite='xonstat',
+      install_requires = requires,
+      entry_points = """\
+      [paste.app_factory]
+      main = xonstat:main
+      """,
+      paster_plugins=['pyramid'],
+      )
+
diff --git a/xonstat/__init__.py b/xonstat/__init__.py
new file mode 100644 (file)
index 0000000..b9b21bc
--- /dev/null
@@ -0,0 +1,17 @@
+from pyramid.config import Configurator
+from sqlalchemy import engine_from_config
+
+from xonstat.models import initialize_sql
+
+def main(global_config, **settings):
+    """ This function returns a Pyramid WSGI application.
+    """
+    engine = engine_from_config(settings, 'sqlalchemy.')
+    initialize_sql(engine)
+    config = Configurator(settings=settings)
+    config.add_static_view('static', 'xonstat:static')
+    config.add_route('home', '/', view='xonstat.views.my_view',
+                     view_renderer='templates/mytemplate.pt')
+    return config.make_wsgi_app()
+
+
diff --git a/xonstat/models.py b/xonstat/models.py
new file mode 100644 (file)
index 0000000..a036e8c
--- /dev/null
@@ -0,0 +1,42 @@
+import transaction
+
+from sqlalchemy import Column
+from sqlalchemy import Integer
+from sqlalchemy import Unicode
+
+from sqlalchemy.exc import IntegrityError
+from sqlalchemy.ext.declarative import declarative_base
+
+from sqlalchemy.orm import scoped_session
+from sqlalchemy.orm import sessionmaker
+
+from zope.sqlalchemy import ZopeTransactionExtension
+
+DBSession = scoped_session(sessionmaker(extension=ZopeTransactionExtension()))
+Base = declarative_base()
+
+class MyModel(Base):
+    __tablename__ = 'models'
+    id = Column(Integer, primary_key=True)
+    name = Column(Unicode(255), unique=True)
+    value = Column(Integer)
+
+    def __init__(self, name, value):
+        self.name = name
+        self.value = value
+
+def populate():
+    session = DBSession()
+    model = MyModel(name=u'root', value=55)
+    session.add(model)
+    session.flush()
+    transaction.commit()
+    
+def initialize_sql(engine):
+    DBSession.configure(bind=engine)
+    Base.metadata.bind = engine
+    Base.metadata.create_all(engine)
+    try:
+        populate()
+    except IntegrityError:
+        DBSession.rollback()
diff --git a/xonstat/static/favicon.ico b/xonstat/static/favicon.ico
new file mode 100644 (file)
index 0000000..71f837c
Binary files /dev/null and b/xonstat/static/favicon.ico differ
diff --git a/xonstat/static/footerbg.png b/xonstat/static/footerbg.png
new file mode 100644 (file)
index 0000000..1fbc873
Binary files /dev/null and b/xonstat/static/footerbg.png differ
diff --git a/xonstat/static/headerbg.png b/xonstat/static/headerbg.png
new file mode 100644 (file)
index 0000000..0596f20
Binary files /dev/null and b/xonstat/static/headerbg.png differ
diff --git a/xonstat/static/ie6.css b/xonstat/static/ie6.css
new file mode 100644 (file)
index 0000000..b7c8493
--- /dev/null
@@ -0,0 +1,8 @@
+* html img,
+* html .png{position:relative;behavior:expression((this.runtimeStyle.behavior="none")&&(this.pngSet?this.pngSet=true:(this.nodeName == "IMG" && this.src.toLowerCase().indexOf('.png')>-1?(this.runtimeStyle.backgroundImage = "none",
+this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.src + "',sizingMethod='image')",
+this.src = "static/transparent.gif"):(this.origBg = this.origBg? this.origBg :this.currentStyle.backgroundImage.toString().replace('url("','').replace('")',''),
+this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.origBg + "',sizingMethod='crop')",
+this.runtimeStyle.backgroundImage = "none")),this.pngSet=true)
+);}
+#wrap{display:table;height:100%}
diff --git a/xonstat/static/middlebg.png b/xonstat/static/middlebg.png
new file mode 100644 (file)
index 0000000..2369cfb
Binary files /dev/null and b/xonstat/static/middlebg.png differ
diff --git a/xonstat/static/pylons.css b/xonstat/static/pylons.css
new file mode 100644 (file)
index 0000000..fd1914d
--- /dev/null
@@ -0,0 +1,65 @@
+html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,font,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td{margin:0;padding:0;border:0;outline:0;font-size:100%;/* 16px */
+vertical-align:baseline;background:transparent;}
+body{line-height:1;}
+ol,ul{list-style:none;}
+blockquote,q{quotes:none;}
+blockquote:before,blockquote:after,q:before,q:after{content:'';content:none;}
+:focus{outline:0;}
+ins{text-decoration:none;}
+del{text-decoration:line-through;}
+table{border-collapse:collapse;border-spacing:0;}
+sub{vertical-align:sub;font-size:smaller;line-height:normal;}
+sup{vertical-align:super;font-size:smaller;line-height:normal;}
+ul,menu,dir{display:block;list-style-type:disc;margin:1em 0;padding-left:40px;}
+ol{display:block;list-style-type:decimal-leading-zero;margin:1em 0;padding-left:40px;}
+li{display:list-item;}
+ul ul,ul ol,ul dir,ul menu,ul dl,ol ul,ol ol,ol dir,ol menu,ol dl,dir ul,dir ol,dir dir,dir menu,dir dl,menu ul,menu ol,menu dir,menu menu,menu dl,dl ul,dl ol,dl dir,dl menu,dl dl{margin-top:0;margin-bottom:0;}
+ol ul,ul ul,menu ul,dir ul,ol menu,ul menu,menu menu,dir menu,ol dir,ul dir,menu dir,dir dir{list-style-type:circle;}
+ol ol ul,ol ul ul,ol menu ul,ol dir ul,ol ol menu,ol ul menu,ol menu menu,ol dir menu,ol ol dir,ol ul dir,ol menu dir,ol dir dir,ul ol ul,ul ul ul,ul menu ul,ul dir ul,ul ol menu,ul ul menu,ul menu menu,ul dir menu,ul ol dir,ul ul dir,ul menu dir,ul dir dir,menu ol ul,menu ul ul,menu menu ul,menu dir ul,menu ol menu,menu ul menu,menu menu menu,menu dir menu,menu ol dir,menu ul dir,menu menu dir,menu dir dir,dir ol ul,dir ul ul,dir menu ul,dir dir ul,dir ol menu,dir ul menu,dir menu menu,dir dir menu,dir ol dir,dir ul dir,dir menu dir,dir dir dir{list-style-type:square;}
+.hidden{display:none;}
+p{line-height:1.5em;}
+h1{font-size:1.75em;line-height:1.7em;font-family:helvetica,verdana;}
+h2{font-size:1.5em;line-height:1.7em;font-family:helvetica,verdana;}
+h3{font-size:1.25em;line-height:1.7em;font-family:helvetica,verdana;}
+h4{font-size:1em;line-height:1.7em;font-family:helvetica,verdana;}
+html,body{width:100%;height:100%;}
+body{margin:0;padding:0;background-color:#ffffff;position:relative;font:16px/24px "Nobile","Lucida Grande",Lucida,Verdana,sans-serif;}
+a{color:#1b61d6;text-decoration:none;}
+a:hover{color:#e88f00;text-decoration:underline;}
+body h1,
+body h2,
+body h3,
+body h4,
+body h5,
+body h6{font-family:"Neuton","Lucida Grande",Lucida,Verdana,sans-serif;font-weight:normal;color:#373839;font-style:normal;}
+#wrap{min-height:100%;}
+#header,#footer{width:100%;color:#ffffff;height:40px;position:absolute;text-align:center;line-height:40px;overflow:hidden;font-size:12px;vertical-align:middle;}
+#header{background:#000000;top:0;font-size:14px;}
+#footer{bottom:0;background:#000000 url(footerbg.png) repeat-x 0 top;position:relative;margin-top:-40px;clear:both;}
+.header,.footer{width:750px;margin-right:auto;margin-left:auto;}
+.wrapper{width:100%}
+#top,#top-small,#bottom{width:100%;}
+#top{color:#000000;height:230px;background:#ffffff url(headerbg.png) repeat-x 0 top;position:relative;}
+#top-small{color:#000000;height:60px;background:#ffffff url(headerbg.png) repeat-x 0 top;position:relative;}
+#bottom{color:#222;background-color:#ffffff;}
+.top,.top-small,.middle,.bottom{width:750px;margin-right:auto;margin-left:auto;}
+.top{padding-top:40px;}
+.top-small{padding-top:10px;}
+#middle{width:100%;height:100px;background:url(middlebg.png) repeat-x;border-top:2px solid #ffffff;border-bottom:2px solid #b2b2b2;}
+.app-welcome{margin-top:25px;}
+.app-name{color:#000000;font-weight:bold;}
+.bottom{padding-top:50px;}
+#left{width:350px;float:left;padding-right:25px;}
+#right{width:350px;float:right;padding-left:25px;}
+.align-left{text-align:left;}
+.align-right{text-align:right;}
+.align-center{text-align:center;}
+ul.links{margin:0;padding:0;}
+ul.links li{list-style-type:none;font-size:14px;}
+form{border-style:none;}
+fieldset{border-style:none;}
+input{color:#222;border:1px solid #ccc;font-family:sans-serif;font-size:12px;line-height:16px;}
+input[type=text],input[type=password]{width:205px;}
+input[type=submit]{background-color:#ddd;font-weight:bold;}
+/*Opera Fix*/
+body:before{content:"";height:100%;float:left;width:0;margin-top:-32767px;}
diff --git a/xonstat/static/pyramid-small.png b/xonstat/static/pyramid-small.png
new file mode 100644 (file)
index 0000000..a5bc0ad
Binary files /dev/null and b/xonstat/static/pyramid-small.png differ
diff --git a/xonstat/static/pyramid.png b/xonstat/static/pyramid.png
new file mode 100644 (file)
index 0000000..347e055
Binary files /dev/null and b/xonstat/static/pyramid.png differ
diff --git a/xonstat/static/transparent.gif b/xonstat/static/transparent.gif
new file mode 100644 (file)
index 0000000..0341802
Binary files /dev/null and b/xonstat/static/transparent.gif differ
diff --git a/xonstat/templates/mytemplate.pt b/xonstat/templates/mytemplate.pt
new file mode 100644 (file)
index 0000000..93f207b
--- /dev/null
@@ -0,0 +1,75 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" xmlns:tal="http://xml.zope.org/namespaces/tal">
+<head>
+  <title>The Pyramid Web Application Development Framework</title>
+  <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/>
+  <meta name="keywords" content="python web application" />
+  <meta name="description" content="pyramid web application" />
+  <link rel="shortcut icon" href="${request.static_url('xonstat:static/favicon.ico')}" />
+  <link rel="stylesheet" href="${request.static_url('xonstat:static/pylons.css')}" type="text/css" media="screen" charset="utf-8" />
+  <link rel="stylesheet" href="http://fonts.googleapis.com/css?family=Neuton|Nobile:regular,i,b,bi&amp;subset=latin" type="text/css" media="screen" charset="utf-8" />
+  <!--[if lte IE 6]>
+  <link rel="stylesheet" href="${request.static_url('xonstat:static/ie6.css')}" type="text/css" media="screen" charset="utf-8" />
+  <![endif]-->
+</head>
+<body>
+  <div id="wrap">
+    <div id="top">
+      <div class="top align-center">
+        <div><img src="${request.static_url('xonstat:static/pyramid.png')}" width="750" height="169" alt="pyramid"/></div>
+      </div>
+    </div>
+    <div id="middle">
+      <div class="middle align-center">
+        <p class="app-welcome">
+          Welcome to <span class="app-name">${project}</span>, an application generated by<br/>
+          the Pyramid web application development framework.
+        </p>
+      </div>
+    </div>
+    <div id="bottom">
+      <div class="bottom">
+        <div id="left" class="align-right">
+          <h2>Search documentation</h2>
+          <form method="get" action="http://docs.pylonsproject.org/projects/pyramid/dev/search.html">
+                <input type="text" id="q" name="q" value="" />
+                <input type="submit" id="x" value="Go" />
+            </form>
+        </div>
+        <div id="right" class="align-left">
+          <h2>Pyramid links</h2>
+          <ul class="links">
+            <li>
+              <a href="http://pylonsproject.org">Pylons Website</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/dev/#narrative-documentation">Narrative Documentation</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/dev/#api-documentation">API Documentation</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/dev/#tutorials">Tutorials</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/dev/#change-history">Change History</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/dev/#sample-applications">Sample Applications</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/dev/#support-and-development">Support and Development</a>
+            </li>
+            <li>
+              <a href="irc://irc.freenode.net#pyramid">IRC Channel</a>
+            </li>
+            </ul>
+        </div>
+      </div>
+    </div>
+  </div>
+  <div id="footer">
+    <div class="footer">&copy; Copyright 2008-2011, Agendaless Consulting.</div>
+  </div>
+</body>
+</html>
diff --git a/xonstat/tests.py b/xonstat/tests.py
new file mode 100644 (file)
index 0000000..cf8e32e
--- /dev/null
@@ -0,0 +1,24 @@
+import unittest
+from pyramid.config import Configurator
+from pyramid import testing
+
+def _initTestingDB():
+    from sqlalchemy import create_engine
+    from xonstat.models import initialize_sql
+    session = initialize_sql(create_engine('sqlite://'))
+    return session
+
+class TestMyView(unittest.TestCase):
+    def setUp(self):
+        self.config = testing.setUp()
+        _initTestingDB()
+
+    def tearDown(self):
+        testing.tearDown()
+
+    def test_it(self):
+        from xonstat.views import my_view
+        request = testing.DummyRequest()
+        info = my_view(request)
+        self.assertEqual(info['root'].name, 'root')
+        self.assertEqual(info['project'], 'XonStat')
diff --git a/xonstat/views.py b/xonstat/views.py
new file mode 100644 (file)
index 0000000..d68062e
--- /dev/null
@@ -0,0 +1,7 @@
+from xonstat.models import DBSession
+from xonstat.models import MyModel
+
+def my_view(request):
+    dbsession = DBSession()
+    root = dbsession.query(MyModel).filter(MyModel.name==u'root').first()
+    return {'root':root, 'project':'XonStat'}