From e3c4b9c548e396a58b8623f899fceb5facd2f52b Mon Sep 17 00:00:00 2001 From: Bernardo Heynemann Date: Sat, 7 May 2011 23:33:25 -0300 Subject: [PATCH] Starting django pyvows --- Makefile | 2 + vows/sandbox/__init__.py | 0 vows/sandbox/main/__init__.py | 0 vows/sandbox/main/models.py | 3 + vows/sandbox/main/tests.py | 16 ++++ vows/sandbox/main/views.py | 14 ++++ vows/sandbox/manage.py | 14 ++++ vows/sandbox/settings.py | 145 ++++++++++++++++++++++++++++++++++ vows/sandbox/urls.py | 26 ++++++ vows/url_vows.py | 32 ++++++++ 10 files changed, 252 insertions(+) create mode 100644 Makefile create mode 100644 vows/sandbox/__init__.py create mode 100644 vows/sandbox/main/__init__.py create mode 100644 vows/sandbox/main/models.py create mode 100644 vows/sandbox/main/tests.py create mode 100644 vows/sandbox/main/views.py create mode 100755 vows/sandbox/manage.py create mode 100644 vows/sandbox/settings.py create mode 100644 vows/sandbox/urls.py create mode 100644 vows/url_vows.py diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..7b2acbf --- /dev/null +++ b/Makefile @@ -0,0 +1,2 @@ +pyvows: + @env PYTHONPATH=$$PYTHONPATH:. pyvows --cover --cover_package=django_pyvows --cover_threshold=100 vows/ diff --git a/vows/sandbox/__init__.py b/vows/sandbox/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/vows/sandbox/main/__init__.py b/vows/sandbox/main/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/vows/sandbox/main/models.py b/vows/sandbox/main/models.py new file mode 100644 index 0000000..71a8362 --- /dev/null +++ b/vows/sandbox/main/models.py @@ -0,0 +1,3 @@ +from django.db import models + +# Create your models here. diff --git a/vows/sandbox/main/tests.py b/vows/sandbox/main/tests.py new file mode 100644 index 0000000..501deb7 --- /dev/null +++ b/vows/sandbox/main/tests.py @@ -0,0 +1,16 @@ +""" +This file demonstrates writing tests using the unittest module. These will pass +when you run "manage.py test". + +Replace this with more appropriate tests for your application. +""" + +from django.test import TestCase + + +class SimpleTest(TestCase): + def test_basic_addition(self): + """ + Tests that 1 + 1 always equals 2. + """ + self.assertEqual(1 + 1, 2) diff --git a/vows/sandbox/main/views.py b/vows/sandbox/main/views.py new file mode 100644 index 0000000..dff562b --- /dev/null +++ b/vows/sandbox/main/views.py @@ -0,0 +1,14 @@ +#!/usr/bin/python +# -*- coding: utf-8 -*- + +# django-pyvows extensions +# https://github.com/rafaelcaricio/django-pyvows + +# Licensed under the MIT license: +# http://www.opensource.org/licenses/mit-license +# Copyright (c) 2011 Rafael Caricio rafael@caricio.com + +from django.http import HttpResponse + +def home(request): + return HttpResponse('hello world') diff --git a/vows/sandbox/manage.py b/vows/sandbox/manage.py new file mode 100755 index 0000000..3e4eedc --- /dev/null +++ b/vows/sandbox/manage.py @@ -0,0 +1,14 @@ +#!/usr/bin/env python +from django.core.management import execute_manager +import imp +try: + imp.find_module('settings') # Assumed to be in the same directory. +except ImportError: + import sys + sys.stderr.write("Error: Can't find the file 'settings.py' in the directory containing %r. It appears you've customized things.\nYou'll have to run django-admin.py, passing it your settings module.\n" % __file__) + sys.exit(1) + +import settings + +if __name__ == "__main__": + execute_manager(settings) diff --git a/vows/sandbox/settings.py b/vows/sandbox/settings.py new file mode 100644 index 0000000..550f07d --- /dev/null +++ b/vows/sandbox/settings.py @@ -0,0 +1,145 @@ +# Django settings for sandbox project. + +DEBUG = True +TEMPLATE_DEBUG = DEBUG + +ADMINS = ( + # ('Your Name', 'your_email@example.com'), +) + +MANAGERS = ADMINS + +DATABASES = { + 'default': { + 'ENGINE': 'django.db.backends.', # Add 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'. + 'NAME': '', # Or path to database file if using sqlite3. + 'USER': '', # Not used with sqlite3. + 'PASSWORD': '', # Not used with sqlite3. + 'HOST': '', # Set to empty string for localhost. Not used with sqlite3. + 'PORT': '', # Set to empty string for default. Not used with sqlite3. + } +} + +# Local time zone for this installation. Choices can be found here: +# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name +# although not all choices may be available on all operating systems. +# On Unix systems, a value of None will cause Django to use the same +# timezone as the operating system. +# If running in a Windows environment this must be set to the same as your +# system time zone. +TIME_ZONE = 'America/Chicago' + +# Language code for this installation. All choices can be found here: +# http://www.i18nguy.com/unicode/language-identifiers.html +LANGUAGE_CODE = 'en-us' + +SITE_ID = 1 + +# If you set this to False, Django will make some optimizations so as not +# to load the internationalization machinery. +USE_I18N = True + +# If you set this to False, Django will not format dates, numbers and +# calendars according to the current locale +USE_L10N = True + +# Absolute filesystem path to the directory that will hold user-uploaded files. +# Example: "/home/media/media.lawrence.com/media/" +MEDIA_ROOT = '' + +# URL that handles the media served from MEDIA_ROOT. Make sure to use a +# trailing slash. +# Examples: "http://media.lawrence.com/media/", "http://example.com/media/" +MEDIA_URL = '' + +# Absolute path to the directory static files should be collected to. +# Don't put anything in this directory yourself; store your static files +# in apps' "static/" subdirectories and in STATICFILES_DIRS. +# Example: "/home/media/media.lawrence.com/static/" +STATIC_ROOT = '' + +# URL prefix for static files. +# Example: "http://media.lawrence.com/static/" +STATIC_URL = '/static/' + +# URL prefix for admin static files -- CSS, JavaScript and images. +# Make sure to use a trailing slash. +# Examples: "http://foo.com/static/admin/", "/static/admin/". +ADMIN_MEDIA_PREFIX = '/static/admin/' + +# Additional locations of static files +STATICFILES_DIRS = ( + # Put strings here, like "/home/html/static" or "C:/www/django/static". + # Always use forward slashes, even on Windows. + # Don't forget to use absolute paths, not relative paths. +) + +# List of finder classes that know how to find static files in +# various locations. +STATICFILES_FINDERS = ( + 'django.contrib.staticfiles.finders.FileSystemFinder', + 'django.contrib.staticfiles.finders.AppDirectoriesFinder', +# 'django.contrib.staticfiles.finders.DefaultStorageFinder', +) + +# Make this unique, and don't share it with anybody. +SECRET_KEY = 'l7#du3ceob9^i^6^jambl@io7nxc^%&))b$uxlxa#-3lake5+w' + +# List of callables that know how to import templates from various sources. +TEMPLATE_LOADERS = ( + 'django.template.loaders.filesystem.Loader', + 'django.template.loaders.app_directories.Loader', +# 'django.template.loaders.eggs.Loader', +) + +MIDDLEWARE_CLASSES = ( + 'django.middleware.common.CommonMiddleware', + 'django.contrib.sessions.middleware.SessionMiddleware', + 'django.middleware.csrf.CsrfViewMiddleware', + 'django.contrib.auth.middleware.AuthenticationMiddleware', + 'django.contrib.messages.middleware.MessageMiddleware', +) + +ROOT_URLCONF = 'sandbox.urls' + +TEMPLATE_DIRS = ( + # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates". + # Always use forward slashes, even on Windows. + # Don't forget to use absolute paths, not relative paths. +) + +INSTALLED_APPS = ( + 'django.contrib.auth', + 'django.contrib.contenttypes', + 'django.contrib.sessions', + 'django.contrib.sites', + 'django.contrib.messages', + 'django.contrib.staticfiles', + # Uncomment the next line to enable the admin: + # 'django.contrib.admin', + # Uncomment the next line to enable admin documentation: + # 'django.contrib.admindocs', +) + +# A sample logging configuration. The only tangible logging +# performed by this configuration is to send an email to +# the site admins on every HTTP 500 error. +# See http://docs.djangoproject.com/en/dev/topics/logging for +# more details on how to customize your logging configuration. +LOGGING = { + 'version': 1, + 'disable_existing_loggers': False, + 'handlers': { + 'mail_admins': { + 'level': 'ERROR', + 'class': 'django.utils.log.AdminEmailHandler' + } + }, + 'loggers': { + 'django.request': { + 'handlers': ['mail_admins'], + 'level': 'ERROR', + 'propagate': True, + }, + } +} diff --git a/vows/sandbox/urls.py b/vows/sandbox/urls.py new file mode 100644 index 0000000..b612db4 --- /dev/null +++ b/vows/sandbox/urls.py @@ -0,0 +1,26 @@ +#!/usr/bin/python +# -*- coding: utf-8 -*- + +# django-pyvows extensions +# https://github.com/rafaelcaricio/django-pyvows + +# Licensed under the MIT license: +# http://www.opensource.org/licenses/mit-license +# Copyright (c) 2011 Rafael Caricio rafael@caricio.com + +from django.conf.urls.defaults import patterns, include, url + +# Uncomment the next two lines to enable the admin: +# from django.contrib import admin +# admin.autodiscover() + +urlpatterns = patterns('', + url(r'^$', 'sandbox.views.home', name='home'), + # url(r'^sandbox/', include('sandbox.foo.urls')), + + # Uncomment the admin/doc line below to enable admin documentation: + # url(r'^admin/doc/', include('django.contrib.admindocs.urls')), + + # Uncomment the next line to enable the admin: + # url(r'^admin/', include(admin.site.urls)), +) diff --git a/vows/url_vows.py b/vows/url_vows.py new file mode 100644 index 0000000..d103960 --- /dev/null +++ b/vows/url_vows.py @@ -0,0 +1,32 @@ +#!/usr/bin/python +# -*- coding: utf-8 -*- + +# django-pyvows extensions +# https://github.com/rafaelcaricio/django-pyvows + +# Licensed under the MIT license: +# http://www.opensource.org/licenses/mit-license +# Copyright (c) 2011 Rafael Caricio rafael@caricio.com + +from os.path import abspath, join, dirname + +from pyvows import Vows, expect +from django_pyvows import DjangoContext, Assertions + +from sandbox.main.views import home + +class UrlVows(DjangoContext): + + def settings_path(self): + return abspath(join(dirname(__file__), 'sandbox', 'settings.py')) + + class Home(Vows.Context): + + def topic(self): + return self._url('/') + + def should_have_home_url_mapped(self, topic): + expect(topic).to_be_mapped() + + def should_have_url_mapped_to_home_view(self, topic): + expect(topic).to_match_view(home)