Skip to content

Commit

Permalink
Merge branch 't9_command' into t10_signal
Browse files Browse the repository at this point in the history
Conflicts:
	testsobol/mainapp/tests.py
  • Loading branch information
andreysobol committed Mar 11, 2012
2 parents 095148d + 097ed64 commit 92a6ef5
Show file tree
Hide file tree
Showing 15 changed files with 164 additions and 81 deletions.
1 change: 1 addition & 0 deletions requirements.txt
@@ -1,2 +1,3 @@
Django==1.3
pil
wsgiref==0.1.2
2 changes: 2 additions & 0 deletions testsobol/Makefile
@@ -0,0 +1,2 @@
test:
python manage.py test mainapp
3 changes: 2 additions & 1 deletion testsobol/mainapp/context_processor.py
@@ -1,4 +1,5 @@
from django.conf import settings


def settings_context_processor(request):
return {'settings':settings}
return {'settings': settings}
12 changes: 9 additions & 3 deletions testsobol/mainapp/forms.py
Expand Up @@ -5,15 +5,18 @@
from models import Bio
from utils import Render


class ImgWidget(ClearableFileInput):

def render(self, name, value, attrs=None):
substitutions = {}
template = u'%(input)s'
substitutions['input'] = super(ClearableFileInput, self).render(name, value, attrs)
substitutions['input'] = super(ClearableFileInput, self)\
.render(name, value, attrs)
if value and hasattr(value, "url"):
template = u'%(initial)s<br />%(input)s'
substitutions['initial'] = (u'<img src="%s"/>' % (escape(value.url)))
substitutions['initial'] = (u'<img src="%s"/>' %\
(escape(value.url)))
return mark_safe(template % substitutions)


Expand All @@ -25,7 +28,10 @@ class Meta:
}

def render(self):
form_field = dict([(field.name, {'label':field.label,'value':field.as_widget(),'errors':field.errors}) for field in self])
form_field = dict([(field.name,
{'label':field.label,
'value':field.as_widget(),
'errors':field.errors}) for field in self])

get = lambda item: form_field[item]

Expand Down
4 changes: 3 additions & 1 deletion testsobol/mainapp/management/commands/printmodels.py
Expand Up @@ -2,9 +2,11 @@
from django.db import models
import sys


class Command(NoArgsCommand):

def handle(self, *args, **options):
p = unicode([(cls.__name__,cls.objects.count()) for cls in models.get_models()])
p = unicode([(cls.__name__, cls.objects.count())
for cls in models.get_models()])
print p
print >> sys.stderr, 'error: ' + p,
3 changes: 2 additions & 1 deletion testsobol/mainapp/middleware.py
Expand Up @@ -2,8 +2,9 @@

from models import Request


class RequestMiddleware(object):

def process_request(self, request):
r = Request()
r.date = datetime.now()
Expand Down
9 changes: 1 addition & 8 deletions testsobol/mainapp/models.py
@@ -1,9 +1,8 @@
from django.db import models
from django.db.models.signals import post_save, post_delete

from utils import Render

class Bio(models.Model, Render):
class Bio(models.Model):
name = models.CharField(max_length=250, verbose_name='Name')
surname = models.CharField(max_length=250, verbose_name='Last name')
birth = models.DateField(verbose_name='Date of birth')
Expand All @@ -14,12 +13,6 @@ class Bio(models.Model, Render):
bio = models.TextField(verbose_name='Bio')
img = models.ImageField(verbose_name='Photo', upload_to='img/')

def render(self):
field_types = dict([(field.name, field.verbose_name) for field in self._meta.fields])

get = lambda item: {'value':unicode(getattr(self,item)) if item!='img' else '<img src="%s" />' % getattr(self,item).url,'label':field_types[item]}

return self.get_struct(get, False)

class Request(models.Model):
date = models.DateTimeField()
Expand Down
6 changes: 5 additions & 1 deletion testsobol/mainapp/templatetags/my_tags.py
@@ -1,16 +1,20 @@
from django.template import Library, Node, Variable
from django.core.urlresolvers import reverse


register = Library()


class EditAdmin(Node):

def __init__(self, edit):
self.edit = Variable(edit)

def render(self, context):
e = self.edit.resolve(context)
return u'<a href="%s">Edit</a>' % reverse('admin:%s_%s_change' % (e._meta.app_label, e._meta.module_name), args=(e.id,))
return u'<a href="%s">Edit</a>' %\
reverse('admin:%s_%s_change' %\
(e._meta.app_label, e._meta.module_name), args=(e.id,))


def ed(parser, token):
Expand Down
113 changes: 78 additions & 35 deletions testsobol/mainapp/tests.py
Expand Up @@ -17,22 +17,24 @@
class IndexViewTest(TestCase):

def test(self):
fixtures = ['initial_data.json']

page = self.client.get('')

self.assertEqual(page.status_code, 200)
for key,value in model_to_dict(Bio.objects.get(pk = 1)).items():
if key!='id':

for key, value in model_to_dict(Bio.objects.get(pk=1)).items():
if key != 'id':
self.assertTrue(page.content.find(unicode(value)) != -1)


class RequestTest(TestCase):

def test(self):
page = self.client.get('')
self.assertTrue(bool(Request.objects.filter(date__gte = (datetime.now() - timedelta(minutes=1)))))

self.assertEqual(page.status_code, 200)

self.assertTrue(bool(Request.objects.filter(
date__gte=(datetime.now() - timedelta(minutes=1)))))


class RequestViewTest(TestCase):
Expand All @@ -42,43 +44,56 @@ def test(self):
self.assertEqual(page.status_code, 200)
self.assertTrue(bool(page.context['custom_request']))


class SettingsContextTest(TestCase):

def test(self):
page = self.client.get('')
self.assertEqual(page.status_code, 200)
self.assertTrue(page.context['settings'])
self.assertEqual(page.context['settings'].STATIC_URL, '/static/')


class Edit(TestCase):

def test(self):
fixtures = ['initial_data.json']

page = self.client.post('/accounts/login/', {'username': 'admin', 'password': 'admin'})
def test(self):
page = self.client.post('/accounts/login/',
{'username': 'admin', 'password': 'admin'})
self.assertEqual(page.status_code, 302)

page = self.client.post('/edit/', {"bio": "Noooooooooooooo", "surname": "Sobol", "name": "Andrey", "other": "pigeon post - white pigeon only", "birth": "1990-09-18", "skype": "andreysobol", "jabber": "pisecs@gmail.com", "email": "asobol@mail.ua"})

s = {"bio": "Noooooooooooooo",
"surname": "Sobol",
"name": "Andrey",
"other": "pigeon post - white pigeon only",
"birth": "1990-09-18",
"skype": "andreysobol",
"jabber": "pisecs@gmail.com",
"email": "asobol@mail.ua"}
page = self.client.post('/edit/', s)
self.assertEqual(page.status_code, 200)
self.assertTrue(page.content == 'Okay')
self.assertTrue(Bio.objects.get(pk = 1).bio == "Noooooooooooooo")

page = self.client.post('/edit/', {"bio": "Noooooooooooooo", "surname": "Sobol", "name": "Andrey", "other": "pigeon post - white pigeon only"})
for t in s:
self.assertEqual(unicode(getattr(Bio.objects.get(pk=1), t)), s[t])

page = self.client.post('/edit/',
{"bio": "Noooooooooooooo",
"surname": "Sobol",
"name": "Andrey",
"other": "pigeon post - white pigeon only"})
self.assertEqual(page.status_code, 200)
self.assertTrue(page.content.find("error") != -1)


class AjaxEdit(TestCase):

def test(self):
fixtures = ['initial_data.json']

page = self.client.post('/accounts/login/', {'username': 'admin', 'password': 'admin'})
page = self.client.post('/accounts/login/',
{'username': 'admin', 'password': 'admin'})
self.assertEqual(page.status_code, 302)

page = self.client.post('/edit/')
self.assertTrue(page.content.find('<body>') == -1)

page = self.client.get('/edit/')
self.assertTrue(page.content.find('<body>') != -1)
self.assertTrue(page.content.find('<script') != -1)
Expand All @@ -90,40 +105,53 @@ def test(self):
class EditReverse(TestCase):

def test(self):
fixtures = ['initial_data.json']

page = self.client.get('/')
self.assertTrue(page.content.find('>Name:') < page.content.find('Last name:'))
self.assertTrue(page.content.find('Bio:') > page.content.find('Other'))
self.assertTrue(page.content.find('>Name:')
< page.content.find('Last name:'))
self.assertTrue(page.content.find('Bio:')
> page.content.find('Other'))

page = self.client.post('/accounts/login/', {'username': 'admin', 'password': 'admin'})
page = self.client.post('/accounts/login/',
{'username': 'admin', 'password': 'admin'})

page = self.client.get('/edit/')
self.assertTrue(page.content.find('>Name:') > page.content.find('Last name:'))
self.assertTrue(page.content.find('Bio:') < page.content.find('Other'))
self.assertTrue(page.content.find('>Name:')
> page.content.find('Last name:'))
self.assertTrue(page.content.find('Bio:')
< page.content.find('Other'))


class Tag(TestCase):

def test(self):
fixtures = ['initial_data.json']
page = self.client.post('/accounts/login/',
{'username': 'admin', 'password': 'admin'})

page = self.client.post('/accounts/login/', {'username': 'admin', 'password': 'admin'})
page = self.client.get('/')
self.assertTrue(page.content.find(
'<a href="/admin/auth/user/1/"') != -1)


class NameUrlTest(TestCase):

def test(self):
page = self.client.get('/')
self.assertTrue(page.content.find('<a href="/admin/auth/user/1/"') != -1 )
self.assertEqual(page.status_code, 200)
self.assertTrue(page.content.find('a href="/http/"') != -1)
self.assertTrue(page.content.find('a href="/edit/"') != -1)


class Command(TestCase):

def test(self):
p = Popen("python manage.py printmodels", stdout=PIPE, stderr=PIPE, shell=True).stdout.read()
self.assertTrue(p.find('Bio')!=-1)
p = Popen("python manage.py printmodels",
stdout=PIPE, stderr=PIPE, shell=True).stdout.read()
self.assertTrue(p.find('Bio') != -1)
Popen("bash save.bash", stdout=PIPE, stderr=PIPE, shell=True)
l = os.listdir(".")
for d in l:
if d.find('.dat')!=-1:
f = open(d,'r')
if d.find('.dat') != -1:
f = open(d, 'r')
self.assertTrue((f.read()).find('error') != -1)
f.close()
Popen("rm " + d, stdout=PIPE, stderr=PIPE, shell=True)
Expand All @@ -132,7 +160,11 @@ def test(self):
class Signal(TestCase):

def test(self):
b = Bio(bio="Noooooooooooooo", surname="Sobol", name="Andrey", other="pigeon post - white pigeon only", birth="1990-09-18", skype="andreysobol", jabber="pisecs@gmail.com", email="asobol@mail.ua", img="img/1.jpg")
b = Bio(bio="Noooooooooooooo", surname="Sobol",
name="Andrey", other="pigeon post - white pigeon only",
birth="1990-09-18", skype="andreysobol",
jabber="pisecs@gmail.com", email="asobol@mail.ua",
img="img/1.jpg")
b.save()
self.assertEqual(Log.objects.order_by('-id')[0].model,'Bio')
self.assertEqual(Log.objects.order_by('-id')[0].signal,'create')
Expand All @@ -145,3 +177,14 @@ def test(self):
b.delete()
self.assertEqual(Log.objects.order_by('-id')[0].model,'Bio')
self.assertEqual(Log.objects.order_by('-id')[0].signal,'delete')


class ManyRequestTest(TestCase):

def test(self):
for t in range(11):
page = self.client.get('/')
self.assertEqual(page.status_code, 200)

page = self.client.get('/http/')
self.assertTrue(page.context['custom_request'].count() == 10)
32 changes: 26 additions & 6 deletions testsobol/mainapp/utils.py
@@ -1,15 +1,35 @@
structs = (
('name','surname','birth','img'),
('email','jabber','skype','other', 'bio'),
structs = (
('name', 'surname', 'birth', 'img'),
('email', 'jabber', 'skype', 'other', 'bio'),
)

multiline = ('bio','other', 'img')
multiline = ('bio', 'other', 'img')


class Render(object):

def get_struct(self, get, reverse):
if reverse:
local_structs = [struct[::-1] for struct in structs]
else:
local_structs = structs
return [[dict(get(item).items() + [('multiline',(item in multiline))]) for item in struct] for struct in local_structs]
return [[dict(get(item).items() + [('multiline', (item in multiline))])
for item in struct]
for struct in local_structs]


class DataRender(Render):

def __init__(self, model):
self.model = model

def render(self):
field_types = dict([(field.name, field.verbose_name) \
for field in self.model._meta.fields])

get = lambda item: {'value':\
unicode(getattr(self.model, item)) if item != 'img'\
else '<img src="%s" />' % getattr(self.model, item).url,
'label': field_types[item]}

return self.get_struct(get, False)

0 comments on commit 92a6ef5

Please sign in to comment.