+
+ def test_edit_zero_value(self):
+ user = meta.Session.query(model.User).\
+ filter_by(name=u'Charlie Root').one()
+ e = model.Expenditure(user, 0, u'A zero value expenditure', None)
+ e.even_split()
+ meta.Session.add(e)
+ meta.Session.commit()
+
+ response = self.app.get(url_for(controller='spend',
+ action='edit',
+ id=e.id))
+ response.mustcontain('Edit an Expenditure')
+ form = response.form
+
+ assert int(form['spender_id'].value) == user.id
+ assert form['amount'].value == '0.00'
+ assert form['date'].value == date.today().strftime('%m/%d/%Y')
+ assert form['description'].value == u'A zero value expenditure'
+ for ii in range(4):
+ assert form['shares-%d.amount' % ii].value == '0'
+
+ def test_edit_nonexistent(self):
+ response = self.app.get(url_for(controller='spend',
+ action='edit',
+ id=124234), status=404)
+
+ def test_update_nonexistent(self):
+ response = self.app.get(url_for(controller='spend',
+ action='edit'))
+ params = self.sample_post.copy()
+ params[token_key] = response.form[token_key].value
+ self.app.post(url_for(controller='spend',
+ action='update',
+ id=14234),
+ params=params,
+ status=404)
+
+ def test_xsrf_protection(self):
+ self.app.post(url_for(controller='spend',
+ action='update'),
+ params=self.sample_post,
+ status=403)
+
+ def test_all_zero_shares_fails(self):
+ params = self.sample_post.copy()
+ for ii in range(4):
+ params['shares-%d.amount' % ii] = '0'
+ v = ExpenditureSchema()
+ try:
+ v.to_python(params)
+ except Invalid:
+ pass
+
+ def setUp(self):
+ self.sample_post = {
+ 'spender_id': '1',
+ 'amount': '44.12',
+ 'date': '10/5/2008',
+ 'description': 'Example expenditure post data.',
+ 'shares-0.user_id': '1',
+ 'shares-0.amount': '1',
+ 'shares-1.user_id': '2',
+ 'shares-1.amount': '1',
+ 'shares-2.user_id': '3',
+ 'shares-2.amount': '1',
+ 'shares-3.user_id': '4',
+ 'shares-3.amount': '1'}
+
+ def tearDown(self):
+ expenditures = meta.Session.query(model.Expenditure).all()
+ for e in expenditures:
+ meta.Session.delete(e)