-
Notifications
You must be signed in to change notification settings - Fork 13
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Patch for step # #43
base: master
Are you sure you want to change the base?
Patch for step # #43
Changes from 9 commits
3858c5d
6a88a1b
548eb86
d7d29bd
04771ab
e763972
8d6f4d2
7b89f24
c7e858b
59f476b
008795e
7ceaaa4
2d03683
071dae9
cb20e0a
a263a96
6278bad
9712373
3a5b3d7
97c075a
bf529cd
f7a6f32
e2a2a15
b100bcd
78904ce
b5812e6
e95284c
c786c5a
193f377
97bf598
86f1c65
f77716f
477f940
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,31 @@ | ||||||
#!/bin/bash | ||||||
|
||||||
set -e | ||||||
set +x | ||||||
|
||||||
project_dir=$(dirname $(dirname $(readlink -f "$0"))) | ||||||
|
||||||
if [ "$1" != "noclean" ] | ||||||
then | ||||||
rm -rf $project_dir/venv | ||||||
python2 -m virtualenv $project_dir/venv | ||||||
|
||||||
. $project_dir/venv/bin/activate | ||||||
pip install -U pip | ||||||
pip install -r $project_dir/truffe2/data/pip-reqs.txt | ||||||
else | ||||||
. $project_dir/venv/bin/activate | ||||||
fi | ||||||
|
||||||
rm -rf $project_dir/truffe2/db.sqlite3 | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Normaly, good developper don't use space in working directory ;) |
||||||
cp $project_dir/tools/settingsLocal.py.test $project_dir/truffe2/app/settingsLocal.py | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Normaly, good developper don't use space in working directory ;) |
||||||
|
||||||
( | ||||||
cd $project_dir/truffe2 | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Normaly, good developper don't use space in working directory ;) |
||||||
python manage.py syncdb | ||||||
python manage.py migrate | ||||||
if [ "$2" == "demo" ] | ||||||
then | ||||||
echo 'from main.test_data import initial_data; initial_data()' | python manage.py shell | ||||||
fi | ||||||
) |
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,16 @@ | ||||||
#!/bin/bash | ||||||
|
||||||
set +e | ||||||
set +x | ||||||
|
||||||
project_dir=$(dirname $(dirname $(readlink -f "$0"))) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Normaly, good developper don't use space in working directory ;) |
||||||
|
||||||
rm -rf $project_dir/htmlcov | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. good idea to protect about this bad using |
||||||
. $project_dir/venv/bin/activate | ||||||
|
||||||
cd $project_dir/truffe2 | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. good idea to protect about this bad using |
||||||
python -m pip install -U coverage >/dev/null | ||||||
python -m coverage erase | ||||||
python -m coverage run --branch --source=. manage.py test | ||||||
# python -m coverage report | ||||||
python -m coverage html -d $project_dir/htmlcov | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. good idea to protect about this bad using |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
from os.path import join, dirname, abspath | ||
DATABASES = { | ||
'default': { | ||
'ENGINE': 'django.db.backends.sqlite3', | ||
'NAME': join(dirname(dirname(abspath(__file__))), 'db.sqlite3'), | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is it really a good idea to use a sqlite3 database since it's not what is used in production ? I suggest using the same database to avoid potential issues There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. IMHO the production database sets even a higher barrier to potentially new developers. I'd rather stay with something simple and if a CI is ever implemented use the production configuration there. In any case, it should be easily replaceable (e.g. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Developers should use the correct database, especially dues to various small changes that can lead to misbehavior and/or missing features. Tests are meaningless if they fail or not depending on the context. Developers should not use sqlite3. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's hard to find developers motivated to code truffe ! I'm against creating supplementary barrier. And Django provide a correct abstraction of the database. To my opinion, we should instead avoid database specific code. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We need to decide on this @the-glu ! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I support @TeoGoddet's argument on this one. |
||
} | ||
} | ||
|
||
SECRET_KEY = "*=)2_8tuf5qym&6szbr%=xz)g8aw=w3z)ltc=+d)iy7v7grj#!" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The Django secret key in test can just be set to "_" or something similar. Random keys like the one proposed may make other developers think you've leaked a key :) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes, of course, it's juste a random key in this case. |
||
|
||
# Deactivate Haystack indexing on save | ||
HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.BaseSignalProcessor' | ||
|
||
# Logging to console, for debug :) | ||
LOGGING = { | ||
'disable_existing_loggers': False, | ||
'version': 1, | ||
'formatters': { | ||
'verbose': { | ||
'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s' | ||
}, | ||
'simple': { | ||
'format': '%(levelname)s %(message)s' | ||
}, | ||
}, | ||
'handlers': { | ||
'console': { | ||
'level': 'DEBUG', | ||
'class': 'logging.StreamHandler', | ||
'formatter': 'simple' | ||
}, | ||
}, | ||
'loggers': { | ||
'django': { | ||
'handlers': ['console'], | ||
'level': 'DEBUG', | ||
'propagate': True, | ||
}, | ||
|
||
'django.db.backends': { | ||
'handlers': ['console'], | ||
'level': 'ERROR', | ||
'propagate': False, | ||
}, | ||
}, | ||
} | ||
|
||
EMAIL_HOST = 'localhost' | ||
EMAIL_PORT = 1025 |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,80 @@ | ||
from django.test import TestCase | ||
# -*- coding: utf-8 -*- | ||
""" | ||
This file demonstrates writing tests using the unittest module. These will pass | ||
when you run "manage.py test". | ||
|
||
# Create your tests here. | ||
Replace this with more appropriate tests for your application. | ||
""" | ||
|
||
from main.test_tools import TruffeTestAbstract | ||
|
||
|
||
class AccountingCoreNoLoginTest(TruffeTestAbstract): | ||
|
||
def test_accountingyear_copy(self): | ||
self.call_check_redirect('/accounting/core/accountingyear/1/copy') | ||
|
||
def test_accountingyear_cost_centers(self): | ||
self.call_check_redirect('/accounting/core/accountingyear/1/cost_centers') | ||
|
||
def test_accountingyear_accounts(self): | ||
self.call_check_redirect('/accounting/core/accountingyear/1/accounts') | ||
|
||
def test_accountingyear_get_leaves_cat(self): | ||
self.call_check_redirect('/accounting/core/accountingyear/1/get_leaves_cat') | ||
|
||
def test_accountingyear_get_parents_cat(self): | ||
self.call_check_redirect('/accounting/core/accountingyear/1/get_parents_cat') | ||
|
||
def test_accountingyear_get_accounts(self): | ||
self.call_check_redirect('/accounting/core/accountingyear/1/get_accounts') | ||
|
||
def test_costcenter_available_list(self): | ||
self.call_check_redirect('/accounting/core/costcenter/available_list') | ||
|
||
def test_account_available_list(self): | ||
self.call_check_redirect('/accounting/core/account/available_list') | ||
|
||
def test_tva_available_list(self): | ||
self.call_check_redirect('/accounting/core/tva/available_list') | ||
|
||
def test_unit_users_available_list(self): | ||
self.call_check_redirect('/accounting/core/unit/1/users_available_list') | ||
|
||
|
||
class AccountingCoreWithLoginTest(TruffeTestAbstract): | ||
|
||
def test_accountingyear_copy(self): | ||
self.call_check_redirect('/accounting/core/accountingyear/1/copy', | ||
redirect_url='/accounting/core/accountingyear/2/edit') | ||
|
||
def test_accountingyear_cost_centers(self): | ||
self.call_check_pdf('/accounting/core/accountingyear/1/cost_centers') | ||
|
||
def test_accountingyear_accounts(self): | ||
self.call_check_pdf('/accounting/core/accountingyear/1/accounts') | ||
|
||
def test_accountingyear_get_leaves_cat(self): | ||
self.call_check_json('/accounting/core/accountingyear/1/get_leaves_cat') | ||
|
||
def test_accountingyear_get_parents_cat(self): | ||
self.call_check_json('/accounting/core/accountingyear/1/get_parents_cat') | ||
|
||
def test_accountingyear_get_accounts(self): | ||
self.call_check_json('/accounting/core/accountingyear/1/get_accounts') | ||
self.call_check_json('/accounting/core/accountingyear/1/get_accounts', data={"outcomes":1}) | ||
self.call_check_json('/accounting/core/accountingyear/1/get_accounts', data={"incomes":1}) | ||
|
||
def test_costcenter_available_list(self): | ||
self.call_check_json('/accounting/core/costcenter/available_list', data={'upk':1, 'ypk':1}) | ||
|
||
def test_account_available_list(self): | ||
self.call_check_json('/accounting/core/account/available_list', data={'ypk':1}) | ||
|
||
def test_tva_available_list(self): | ||
self.call_check_json('/accounting/core/tva/available_list') | ||
self.call_check_json('/accounting/core/tva/available_list', data={'q':10}) | ||
self.call_check_json('/accounting/core/tva/available_list', data={'init':10}) | ||
|
||
def test_unit_users_available_list(self): | ||
self.call_check_json('/accounting/core/unit/1/users_available_list') |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Normaly, good developper don't use space in working directory ;)
But, it's a good idea to protect about this bad using
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Spaces are a valid POSIX path component. There's no reason to make any assumptions whatsoever about how the project may be deployed or developed.
There's no way to forsee how code will evolve, and this is precisely the kind to bugs that may have disastrous consequences on the user's machine.