Commits

Takumi IINO committed 82981f1

initial import

  • Participants

Comments (0)

Files changed (31)

+syntax: glob
+
+*.py[cod]
+
+# C extensions
+*.so
+
+# Packages
+*.egg
+*.egg-info
+dist
+build
+eggs
+parts
+bin
+var
+sdist
+develop-eggs
+.installed.cfg
+lib
+lib64
+
+# Installer logs
+pip-log.txt
+
+# Unit test / coverage reports
+.coverage
+.tox
+nosetests.xml
+coverage.xml
+
+#Translations
+*.mo
+
+#Mr Developer
+.mr.developer.cfg
+0.0
+---
+
+-  Initial version
+include *.txt *.ini *.cfg *.rst
+recursive-include pyramidapp *.ico *.png *.css *.gif *.jpg *.pt *.txt *.mak *.mako *.js *.html *.xml
+pyramidapp README
+==================
+
+Getting Started
+---------------
+
+- cd <directory containing this file>
+
+- $venv/bin/python setup.py develop
+
+- $venv/bin/populate_pyramidapp development.ini
+
+- $venv/bin/pserve development.ini
+

config/nginx.conf

+# %(application)s.conf
+
+upstream myapp-site {
+    server 127.0.0.1:5000;
+    server 127.0.0.1:5001;
+}
+
+server {
+    server_name  %(server_name)s;
+
+    access_log  %(shared_path)s/log/access.log;
+
+    location / {
+        proxy_set_header        Host $host;
+        proxy_set_header        X-Real-IP $remote_addr;
+        proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
+        proxy_set_header        X-Forwarded-Proto $scheme;
+
+        client_max_body_size    10m;
+        client_body_buffer_size 128k;
+        proxy_connect_timeout   60s;
+        proxy_send_timeout      90s;
+        proxy_read_timeout      90s;
+        proxy_buffering         off;
+        proxy_temp_file_write_size 64k;
+        proxy_pass http://myapp-site;
+        proxy_redirect          off;
+    }
+}
+[app:main]
+use = egg:pyramidapp
+
+pyramid.reload_templates = true
+pyramid.debug_authorization = false
+pyramid.debug_notfound = false
+pyramid.debug_routematch = false
+pyramid.default_locale_name = en
+pyramid.includes =
+    pyramid_debugtoolbar
+    pyramid_tm
+
+sqlalchemy.url = sqlite:///%(here)s/pyramidapp.db
+
+[server:main]
+use = egg:waitress#main
+host = 0.0.0.0
+port = 6543
+
+# Begin logging configuration
+
+[loggers]
+keys = root, pyramidapp, sqlalchemy
+
+[handlers]
+keys = console
+
+[formatters]
+keys = generic
+
+[logger_root]
+level = INFO
+handlers = console
+
+[logger_pyramidapp]
+level = DEBUG
+handlers =
+qualname = pyramidapp
+
+[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

fabfile/__init__.py

+from fabric.api import *
+from fabric_deploy import options
+from fabric_deploy import scm
+import ci
+import deploy
+import app
+import web
+import os
+
+options.set('user',   'rackhuber')
+options.set('runner', 'rackhuber')
+
+options.set('scm', 'hg')
+options.set('application', 'pyramidapp')
+options.set('repository', 'ssh://hg@bitbucket.org/troter/pyramidapp')
+options.set('branch', 'default')
+
+options.set('deploy_to',
+    (lambda: '/home/%(user)s/u/apps/%(name)s' % dict(user=options.fetch('user'), name=options.fetch('application'))))
+
+options.set('revision', 'default')
+options.set('virtualenv', None)
+
+class Mercurial(scm.SCM):
+  def head(self, *args, **kwargs):
+    return options.fetch('revision')
+
+  def checkout(self, *args, **kwargs):
+      return "echo 1"
+
+  def __str__(self):
+    return "mercurial"
+
+  def repository_path(self, path):
+    realpath = os.path.realpath(path)
+    repository = os.path.join(realpath, '.hg')
+    if os.path.isdir(repository):
+      return realpath
+    else:
+      if realpath == os.path.sep:
+        return None
+      else:
+        return self.repository_path(os.path.join(realpath, '..'))
+
+
+options.source_table.update({
+    'hg': Mercurial
+})
+
+env.use_ssh_config = True
+env.roledefs.update({
+    'ci':  [ 'troter-pyfes-ci.rackbox.net' ],
+})
+
+@task
+def production():
+    env.server_name = 'troter-pyfes-ci.rackbox.net'
+    options.set('current_stage', 'production')
+    env.roledefs.update({
+        'app': [ 'troter-pyfes-ci.rackbox.net' ],
+        'web': [ 'troter-pyfes-ci.rackbox.net' ],
+    })
+# -*- coding: utf-8 -*-
+
+from fabric.api import *
+from fabric.colors import *
+from fabric.contrib.files import *
+from utils import apt_get
+
+@task
+@roles('ci')
+def install_packages():
+    sudo(apt_get("update"))
+    sudo(apt_get("install mercurial"))
+
+@task
+@roles('ci')
+def install_jenkins():
+    sudo("wget -q -O - http://pkg.jenkins-ci.org/debian/jenkins-ci.org.key | apt-key add -")
+    sudo("echo deb http://pkg.jenkins-ci.org/debian binary/ > /etc/apt/sources.list.d/jenkins.list")
+    sudo(apt_get("update"))
+    sudo(apt_get("install jenkins"))
+    sed("/etc/default/jenkins", "HTTP_PORT=8080", "HTTP_PORT=3000", use_sudo=True)
+
+@task
+@roles('ci')
+def install_pythonbrew():
+    sudo(apt_get("install libbz2-dev"))
+    with cd("/var/lib/jenkins"):
+        sudo("su - jenkins -c 'curl -skLO http://xrl.us/pythonbrewinstall'")
+        sudo("su - jenkins -c 'bash pythonbrewinstall'")
+        sudo("su - jenkins -c 'source .pythonbrew/etc/bashrc && pythonbrew install 2.7.3'")
+
+@task
+@roles('ci')
+def generate_key():
+    with cd("/var/lib/jenkins"):
+        with settings(warn_only=True):
+            sudo("su - jenkins -c 'ssh-keygen -t rsa -N \"\" -f ~/.ssh/id_rsa.bitbucket'")
+            sudo("su - jenkins -c 'ssh-keygen -t rsa -N \"\" -f ~/.ssh/id_rsa.deploy'")
+        sudo("su - jenkins -c 'echo > ~/.ssh/config'")
+        sudo("su - jenkins -c 'echo  \"Host bitbucket.org\"                     >> ~/.ssh/config'")
+        sudo("su - jenkins -c 'echo  \"  Hostname bitbucket.org\"               >> ~/.ssh/config'")
+        sudo("su - jenkins -c 'echo  \"  IdentityFile ~/.ssh/id_rsa.bitbucket\" >> ~/.ssh/config'")
+        sudo("su - jenkins -c 'echo  \"  StrictHostKeyChecking no\"             >> ~/.ssh/config'")
+        sudo("su - jenkins -c 'cat ~/.ssh/id_rsa.bitbucket.pub'")
+        sudo("su - jenkins -c 'cat ~/.ssh/id_rsa.deploy.pub'")
+
+    
+def jenkins_cli(command):
+    if not exists("jenkins-cli.jar"):
+        run("curl -skLO http://localhost:3000/jnlpJars/jenkins-cli.jar")
+    return "java -jar jenkins-cli.jar -s http://localhost:3000/ %s" % command
+
+@task
+@roles('ci')
+def install_jenkins_plugin():
+    run(jenkins_cli("install-plugin mercurial"))
+    run(jenkins_cli("install-plugin shiningpanda"))
+    run(jenkins_cli("install-plugin analysis-core"))
+    run(jenkins_cli("install-plugin cobertura"))
+    run(jenkins_cli("install-plugin tasks"))
+    run(jenkins_cli("install-plugin build-pipeline-plugin"))
+    run(jenkins_cli("install-plugin clone-workspace-scm"))
+    run(jenkins_cli("install-plugin copyartifact"))
+
+@task
+@roles('ci')
+def setup():
+    install_packages()
+    install_jenkins()
+    install_pythonbrew()
+    restart()
+
+@task
+@roles('ci')
+def help():
+    print green("fab ci.setup ci")
+    print green("# wait startup...")
+    print green("fab ci.install_jenkins_plugin ci.restart")
+
+@task
+@roles('ci')
+def start():
+    sudo("service jenkins start", pty=False)
+
+@task
+@roles('ci')
+def stop():
+    sudo("service jenkins stop", pty=False)
+
+@task
+@roles('ci')
+def status():
+    sudo("service jenkins status", pty=False)
+
+@task
+@roles('ci')
+def restart():
+    sudo("service jenkins restart", pty=False)

fabfile/deploy.py

+# -*- coding: utf-8 -*-
+
+from fabric.api import *
+from fabric.contrib.files import *
+from fabric_deploy.deploy import *
+
+original_setup = setup
+del setup
+
+@task
+@roles('app')
+def setup():
+    setup_deployuser()
+    original_setup()
+    setup_shared()
+
+@task
+@roles('app')
+def setup_deployuser():
+    run("pip install virtualenv")
+
+@task
+@roles('app')
+def setup_shared():
+    dirs = map(lambda path: os.path.join(fetch('shared_path'), path), ['db'])
+    run('mkdir -p %(dirs)s && chmod g+w %(dirs)s' % dict(dirs=' '.join(dirs)))
+
+@task
+@roles('app', 'web')
+def update():
+    invoke('update_code')
+    install()
+    replace_code()
+    shared_symlink()
+    invoke('symlink')
+
+@task
+@roles('app', 'web')
+def install():
+    venv = "%(latest_release)s/env" % var('latest_release')
+    run("virtualenv %s" % venv)
+    activate = "source %s/bin/activate" % venv
+    with cd("%(latest_release)s/" % var('latest_release')):
+        run(activate + '&&' + "python setup.py develop")
+
+@task
+@roles('app', 'web')
+def replace_code():
+    with cd("%(latest_release)s/" % var('latest_release')):
+        sed('supervisord.conf', "%\(current_stage\)s", fetch('current_stage'))
+        sed('supervisord.conf', "%\(application\)s", fetch('application'))
+        #sed('supervisord.conf', "%\(here\)s", fetch('current_path'))
+
+@task
+@roles('app', 'web')
+def shared_symlink():
+    sudo("ln -s %(shared_path)s/db %(latest_release)s/db" % var('latest_release', 'shared_path'))
+
+@task
+@roles('app')
+def migrate():
+    with cd(fetch('current_path')):
+        sudo("env/bin/initialize_pyramidapp_db %(current_stage)s.ini" % var('current_stage'), user=fetch('runner'))
+
+@task
+@roles('app')
+def start():
+    with cd(fetch('current_path')):
+        if not exists('tmp/pids/supervisord.pid'):
+            sudo("env/bin/supervisord -c supervisord.conf", user=fetch('runner'))
+
+@task
+@roles('app')
+def stop():
+    with cd(fetch('current_path')):
+        if exists('tmp/pids/supervisord.pid'):
+            sudo("kill `cat tmp/pids/supervisord.pid`", user=fetch('runner'))
+
+@task
+@roles('app')
+def restart():
+    stop()
+    start()
+
+@task
+@roles('app')
+def restart_hup():
+    with cd(fetch('current_path')):
+        if exists('tmp/pids/supervisord.pid'):
+            sudo("kill -HUP`cat tmp/pids/supervisord.pid`", user=fetch('runner'))
+        else:
+            sudo("env/bin/supervisord -c supervisord.conf", user=fetch('runner'))
+
+@task
+@roles('app')
+def status():
+    with cd(fetch('current_path')):
+        sudo("""
+            env/bin/supervisorctl -c supervisord.conf status
+        """ % var('application'), user=fetch('runner'))
+# -*- coding: utf-8 -*-
+
+def apt_get(command):
+    return "DEBIAN_FRONTEND=noninteractive apt-get -q -y %s" % command
+# -*- coding: utf-8 -*-
+
+from fabric.api import *
+from fabric.contrib.files import *
+from fabric_deploy import options
+from utils import apt_get
+
+nginx_conf = "config/nginx.conf"
+options.set('nginx_sites_available',
+    (lambda: '/etc/nginx/sites-available/%(application)s.conf' % dict(application=options.fetch('application'))))
+options.set('nginx_sites_enabled',
+    (lambda: '/etc/nginx/sites-enabled/%(application)s.conf' % dict(application=options.fetch('application'))))
+
+@task
+@roles('web')
+def setup():
+    sudo(apt_get("install nginx"))
+
+@task
+@roles('web')
+def deploy():
+    update()
+    enabled()
+    restart()
+
+@task
+@roles('web')
+def update():
+    put(nginx_conf, options.fetch('nginx_sites_available'), use_sudo=True)
+    sed(options.fetch('nginx_sites_available'), "%\(application\)s", options.fetch('application'), use_sudo=True)
+    sed(options.fetch('nginx_sites_available'), "%\(shared_path\)s", options.fetch('shared_path'), use_sudo=True)
+    sed(options.fetch('nginx_sites_available'), "%\(server_name\)s", env.server_name, use_sudo=True)
+
+@task
+@roles('web')
+def enabled():
+    if not exists(options.fetch('nginx_sites_enabled')):
+        sudo("ln -s %s %s", options.fetch('nginx_sites_available'), options.fetch('nginx_sites_enabled'))
+
+@task
+@roles('web')
+def disabled():
+    if exists(options.fetch('nginx_sites_enabled')):
+        sudo("rm %s", options.fetch('nginx_sites_enabled'))
+
+@task
+@roles('web')
+def start():
+    sudo("sudo service nginx start", pty=False)
+
+@task
+@roles('web')
+def stop():
+    sudo("sudo service nginx stop", pty=False)
+
+@task
+@roles('web')
+def restart():
+    sudo("sudo service nginx restart", pty=False)
+
+@task
+@roles('web')
+def status():
+    sudo("sudo service nginx status", pty=False)
+[app:main]
+use = egg:pyramidapp
+
+pyramid.reload_templates = false
+pyramid.debug_authorization = false
+pyramid.debug_notfound = false
+pyramid.debug_routematch = false
+pyramid.default_locale_name = en
+pyramid.includes =
+    pyramid_tm
+
+sqlalchemy.url = sqlite:///%(here)s/db/pyramidapp.db
+
+[server:main]
+use = egg:waitress#main
+host = 0.0.0.0
+port = %(http_port)s
+
+# Begin logging configuration
+
+[loggers]
+keys = root, pyramidapp, sqlalchemy
+
+[handlers]
+keys = console
+
+[formatters]
+keys = generic
+
+[logger_root]
+level = WARN
+handlers = console
+
+[logger_pyramidapp]
+level = WARN
+handlers =
+qualname = pyramidapp
+
+[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

pyramidapp/__init__.py

+from pyramid.config import Configurator
+from sqlalchemy import engine_from_config
+
+from .models import DBSession
+
+def main(global_config, **settings):
+    """ This function returns a Pyramid WSGI application.
+    """
+    engine = engine_from_config(settings, 'sqlalchemy.')
+    DBSession.configure(bind=engine)
+    config = Configurator(settings=settings)
+    config.add_static_view('static', 'static', cache_max_age=3600)
+    config.add_route('home', '/')
+    config.scan()
+    return config.make_wsgi_app()
+

pyramidapp/models.py

+from sqlalchemy import (
+    Column,
+    Integer,
+    Text,
+    )
+
+from sqlalchemy.ext.declarative import declarative_base
+
+from sqlalchemy.orm import (
+    scoped_session,
+    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(Text, unique=True)
+    value = Column(Integer)
+
+    def __init__(self, name, value):
+        self.name = name
+        self.value = value
+

pyramidapp/scripts/__init__.py

+# package

pyramidapp/scripts/initializedb.py

+import os
+import sys
+import transaction
+
+from sqlalchemy import engine_from_config
+
+from pyramid.paster import (
+    get_appsettings,
+    setup_logging,
+    )
+
+from ..models import (
+    DBSession,
+    MyModel,
+    Base,
+    )
+
+def usage(argv):
+    cmd = os.path.basename(argv[0])
+    print('usage: %s <config_uri>\n'
+          '(example: "%s development.ini")' % (cmd, cmd)) 
+    sys.exit(1)
+
+def main(argv=sys.argv):
+    if len(argv) != 2:
+        usage(argv)
+    config_uri = argv[1]
+    setup_logging(config_uri)
+    settings = get_appsettings(config_uri)
+    engine = engine_from_config(settings, 'sqlalchemy.')
+    DBSession.configure(bind=engine)
+    Base.metadata.create_all(engine)
+    with transaction.manager:
+        model = MyModel(name='one', value=1)
+        DBSession.add(model)

pyramidapp/static/favicon.ico

Added
New image

pyramidapp/static/footerbg.png

Added
New image

pyramidapp/static/headerbg.png

Added
New image

pyramidapp/static/ie6.css

+* 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%}

pyramidapp/static/middlebg.png

Added
New image

pyramidapp/static/pylons.css

+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 "NobileRegular","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:"NeutonRegular","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;}

pyramidapp/static/pyramid-small.png

Added
New image

pyramidapp/static/pyramid.png

Added
New image

pyramidapp/static/transparent.gif

Added
New image

pyramidapp/templates/mytemplate.pt

+<!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('pyramidapp:static/favicon.ico')}" />
+  <link rel="stylesheet" href="${request.static_url('pyramidapp:static/pylons.css')}" type="text/css" media="screen" charset="utf-8" />
+  <link rel="stylesheet" href="http://static.pylonsproject.org/fonts/nobile/stylesheet.css" media="screen" />
+  <link rel="stylesheet" href="http://static.pylonsproject.org/fonts/neuton/stylesheet.css" media="screen" />
+  <!--[if lte IE 6]>
+  <link rel="stylesheet" href="${request.static_url('pyramidapp: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('pyramidapp: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/en/1.3-branch/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/en/1.3-branch/#narrative-documentation">Narrative Documentation</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/en/1.3-branch/#reference-material">API Documentation</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/en/1.3-branch/#tutorials">Tutorials</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/en/1.3-branch/#detailed-change-history">Change History</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/en/1.3-branch/#sample-applications">Sample Applications</a>
+            </li>
+            <li>
+              <a href="http://docs.pylonsproject.org/projects/pyramid/en/1.3-branch/#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>

pyramidapp/tests.py

+import unittest
+import transaction
+
+from pyramid import testing
+
+from .models import DBSession
+
+class TestMyView(unittest.TestCase):
+    def setUp(self):
+        self.config = testing.setUp()
+        from sqlalchemy import create_engine
+        engine = create_engine('sqlite://')
+        from .models import (
+            Base,
+            MyModel,
+            )
+        DBSession.configure(bind=engine)
+        Base.metadata.create_all(engine)
+        with transaction.manager:
+            model = MyModel(name='one', value=55)
+            DBSession.add(model)
+
+    def tearDown(self):
+        DBSession.remove()
+        testing.tearDown()
+
+    def test_it(self):
+        from .views import my_view
+        request = testing.DummyRequest()
+        info = my_view(request)
+        self.assertEqual(info['one'].name, 'one')
+        self.assertEqual(info['project'], 'pyramidapp')

pyramidapp/views.py

+from pyramid.response import Response
+from pyramid.view import view_config
+
+from sqlalchemy.exc import DBAPIError
+
+from .models import (
+    DBSession,
+    MyModel,
+    )
+
+@view_config(route_name='home', renderer='templates/mytemplate.pt')
+def my_view(request):
+    try:
+        one = DBSession.query(MyModel).filter(MyModel.name=='one').first()
+    except DBAPIError:
+        return Response(conn_err_msg, content_type='text/plain', status_int=500)
+    return {'one':one, 'project':'pyramidapp'}
+
+conn_err_msg = """\
+Pyramid is having a problem using your SQL database.  The problem
+might be caused by one of the following things:
+
+1.  You may need to run the "initialize_pyramidapp_db" script
+    to initialize your database tables.  Check your virtual 
+    environment's "bin" directory for this script and try to run it.
+
+2.  Your database server may not be running.  Check that the
+    database server referred to by the "sqlalchemy.url" setting in
+    your "development.ini" file is running.
+
+After you fix the problem, please restart the Pyramid application to
+try it again.
+"""
+
+[nosetests]
+match=^test
+nocapture=1
+cover-package=pyramidapp
+with-coverage=1
+cover-erase=1
+
+[compile_catalog]
+directory = pyramidapp/locale
+domain = pyramidapp
+statistics = true
+
+[extract_messages]
+add_comments = TRANSLATORS:
+output_file = pyramidapp/locale/pyramidapp.pot
+width = 80
+
+[init_catalog]
+domain = pyramidapp
+input_file = pyramidapp/locale/pyramidapp.pot
+output_dir = pyramidapp/locale
+
+[update_catalog]
+domain = pyramidapp
+input_file = pyramidapp/locale/pyramidapp.pot
+output_dir = pyramidapp/locale
+previous = true
+import os
+
+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',
+    'pyramid_tm',
+    'pyramid_debugtoolbar',
+    'zope.sqlalchemy',
+    'waitress',
+    'nose',
+    'coverage',
+    'fabric',
+    'fabric_deploy',
+    'supervisor',
+    ]
+
+setup(name='pyramidapp',
+      version='0.0',
+      description='pyramidapp',
+      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='pyramidapp',
+      install_requires=requires,
+      entry_points="""\
+      [paste.app_factory]
+      main = pyramidapp:main
+      [console_scripts]
+      initialize_pyramidapp_db = pyramidapp.scripts.initializedb:main
+      """,
+      )
+
+[unix_http_server]
+file=%(here)s/tmp/supervisor.sock
+
+[supervisord]
+pidfile=%(here)s/tmp/pids/supervisord.pid
+logfile=%(here)s/log/supervisord.log
+logfile_maxbytes=50MB
+logfile_backups=10
+loglevel=info
+nodaemon=false
+minfds=1024
+minprocs=200
+
+[rpcinterface:supervisor]
+supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
+
+[supervisorctl]
+serverurl=unix://%(here)s/tmp/supervisor.sock
+
+[program:%(application)s]
+command=%(here)s/env/bin/pserve %(here)s/%(current_stage)s.ini http_port=50%(process_num)02d
+process_name=%(program_name)s-%(process_num)01d
+numprocs=2
+numprocs_start=0
+redirect_stderr=true
+stdout_logfile=%(here)s/log/%(program_name)s-%(process_num)01d.log