|
@ -1,6 +1,9 @@ |
|
|
from django.apps import apps |
|
|
from django.apps import apps |
|
|
from django.contrib.auth.models import Group, Permission |
|
|
from django.contrib.auth.models import Group, Permission |
|
|
from django.contrib.contenttypes.models import ContentType |
|
|
from django.contrib.contenttypes.models import ContentType |
|
|
|
|
|
from django.utils.translation import string_concat |
|
|
|
|
|
|
|
|
|
|
|
from django.utils.translation import ugettext_lazy as _ |
|
|
import pytest |
|
|
import pytest |
|
|
|
|
|
|
|
|
from inicializa_grupos_autorizacoes import cria_grupos_permissoes |
|
|
from inicializa_grupos_autorizacoes import cria_grupos_permissoes |
|
@ -17,12 +20,25 @@ def test_grupo_padrao_tem_permissoes_sobre_todo_o_app(app_label): |
|
|
|
|
|
|
|
|
app = apps.get_app_config(app_label) |
|
|
app = apps.get_app_config(app_label) |
|
|
|
|
|
|
|
|
|
|
|
for klass in list(app.get_models()): |
|
|
|
|
|
opts = klass._meta |
|
|
|
|
|
permissions = ( |
|
|
|
|
|
("list_" + opts.model_name, |
|
|
|
|
|
string_concat( |
|
|
|
|
|
_('Visualizaçao da lista de'), ' ', |
|
|
|
|
|
opts.verbose_name_plural)), |
|
|
|
|
|
("detail_" + opts.model_name, |
|
|
|
|
|
string_concat( |
|
|
|
|
|
_('Visualização dos detalhes de'), ' ', |
|
|
|
|
|
opts.verbose_name_plural)), |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
# código testado |
|
|
# código testado |
|
|
cria_grupos_permissoes() |
|
|
cria_grupos_permissoes() |
|
|
|
|
|
|
|
|
def gerar_permissoes(app): |
|
|
def gerar_permissoes(app): |
|
|
for model in app.get_models(): |
|
|
for model in app.get_models(): |
|
|
for op in ['add', 'change', 'delete']: |
|
|
for op in ['add', 'change', 'delete', 'list', 'detail']: |
|
|
yield model, 'Can %s %s' % (op, model._meta.verbose_name) |
|
|
yield model, 'Can %s %s' % (op, model._meta.verbose_name) |
|
|
grupo = Group.objects.get(name='Operador de %s' % app.verbose_name) |
|
|
grupo = Group.objects.get(name='Operador de %s' % app.verbose_name) |
|
|
esperado = set(gerar_permissoes(app)) |
|
|
esperado = set(gerar_permissoes(app)) |
|
@ -36,6 +52,20 @@ def test_grupo_padrao_tem_permissoes_sobre_todo_o_app(app_label): |
|
|
def test_permissoes_extras_sao_apagadas(app_label): |
|
|
def test_permissoes_extras_sao_apagadas(app_label): |
|
|
|
|
|
|
|
|
app = apps.get_app_config(app_label) |
|
|
app = apps.get_app_config(app_label) |
|
|
|
|
|
|
|
|
|
|
|
for klass in list(app.get_models()): |
|
|
|
|
|
opts = klass._meta |
|
|
|
|
|
permissions = ( |
|
|
|
|
|
("list_" + opts.model_name, |
|
|
|
|
|
string_concat( |
|
|
|
|
|
_('Visualizaçao da lista de'), ' ', |
|
|
|
|
|
opts.verbose_name_plural)), |
|
|
|
|
|
("detail_" + opts.model_name, |
|
|
|
|
|
string_concat( |
|
|
|
|
|
_('Visualização dos detalhes de'), ' ', |
|
|
|
|
|
opts.verbose_name_plural)), |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
grupo = Group.objects.create(name='Operador de %s' % app.verbose_name) |
|
|
grupo = Group.objects.create(name='Operador de %s' % app.verbose_name) |
|
|
|
|
|
|
|
|
permissao_errada = Permission.objects.create( |
|
|
permissao_errada = Permission.objects.create( |
|
|