From 4bf1a0fdf45264bad39a349e36029876e6529fb7 Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Thu, 20 Oct 2016 15:14:12 -0200 Subject: [PATCH 01/16] Fix #722 --- sapl/materia/views.py | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/sapl/materia/views.py b/sapl/materia/views.py index 492091880..7cd83a2ea 100644 --- a/sapl/materia/views.py +++ b/sapl/materia/views.py @@ -123,7 +123,6 @@ def recuperar_materia(request): OrgaoCrud = CrudAux.build(Orgao, 'orgao') TipoProposicaoCrud = CrudAux.build(TipoProposicao, 'tipo_proposicao') StatusTramitacaoCrud = CrudAux.build(StatusTramitacao, 'status_tramitacao') -UnidadeTramitacaoCrud = CrudAux.build(UnidadeTramitacao, 'unidade_tramitacao') def criar_materia_proposicao(proposicao): @@ -304,6 +303,32 @@ class ConfirmarProposicao(PermissionRequiredMixin, CreateView): reverse('sapl.materia:proposicao-devolvida')) +class UnidadeTramitacaoCrud(CrudAux): + model = UnidadeTramitacao + help_path = 'unidade_tramitacao' + + class BaseMixin(Crud.BaseMixin): + list_field_names = ['comissao', 'orgao', 'parlamentar'] + + class ListView(Crud.ListView): + template_name = "crud/list.html" + + def get_headers(self): + return [_('Unidade de Tramitação')] + + def get_context_data(self, **kwargs): + context = super().get_context_data(**kwargs) + for row in context['rows']: + if row[0][0]: # Comissão + pass + elif row[1][0]: # Órgão + row[0] = (row[1][0], row[0][1]) + elif row[2][0]: # Parlamentar + row[0] = (row[2][0], row[0][1]) + row[1], row[2] = ('', ''), ('', '') + return context + + class ProposicaoCrud(Crud): """ TODO: Entre outros comportamento gerais, mesmo que um usuário tenha @@ -518,7 +543,7 @@ class TramitacaoCrud(MasterDetailCrud): class BaseMixin(MasterDetailCrud.BaseMixin): list_field_names = ['data_tramitacao', 'unidade_tramitacao_local', - 'unidade_tramitacao_destino', 'status'] + 'mitacao_destino', 'status'] ordered_list = False ordering = '-data_tramitacao', From caaa0854c894886a2e1f812d404dd06541806df9 Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Thu, 20 Oct 2016 15:28:51 -0200 Subject: [PATCH 02/16] =?UTF-8?q?Adiciona=20op=C3=A7=C3=A3o=20'Tanto=20Faz?= =?UTF-8?q?'=20na=20pesquisa=20de=20mat=C3=A9ria=20(tramita=C3=A7=C3=A3o)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/materia/forms.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/sapl/materia/forms.py b/sapl/materia/forms.py index b41549018..a483f48fa 100644 --- a/sapl/materia/forms.py +++ b/sapl/materia/forms.py @@ -497,6 +497,10 @@ class MateriaLegislativaFilterSet(django_filters.FilterSet): ementa = django_filters.CharFilter(lookup_expr='icontains') + em_tramitacao = django_filters.ChoiceFilter(required=False, + label=u'Ano da Matéria', + choices=em_tramitacao) + class Meta: model = MateriaLegislativa fields = ['numero', From 56ca3a348bb4501af63603e905749c274917133e Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Thu, 20 Oct 2016 15:29:56 -0200 Subject: [PATCH 03/16] =?UTF-8?q?Conserta=20layout=20de=20pesquisa=20de=20?= =?UTF-8?q?mat=C3=A9ria?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/materia/forms.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sapl/materia/forms.py b/sapl/materia/forms.py index a483f48fa..26f14a64b 100644 --- a/sapl/materia/forms.py +++ b/sapl/materia/forms.py @@ -567,7 +567,7 @@ class MateriaLegislativaFilterSet(django_filters.FilterSet): 'limpar Autor', css_class='btn btn-primary btn-sm'), 10)]) row5 = to_row( - [('autoria__autor__tipo', 6), + [('autoria__autor__tipo', 12), # ('autoria__autor__partido', 6) ]) row6 = to_row( From bccb8c5a938c39814189fd19bcad62c51068e8bb Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Thu, 20 Oct 2016 15:52:38 -0200 Subject: [PATCH 04/16] Conserta link para relatorios --- sapl/templates/index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sapl/templates/index.html b/sapl/templates/index.html index f5e70ae71..d4c2e9639 100644 --- a/sapl/templates/index.html +++ b/sapl/templates/index.html @@ -156,7 +156,7 @@ Contém informações estatísticas sobre a produção legislativa dos parlamentares e da Casa, dispostas e agrupadas de diferentes formas de acordo com parâmetros fornecidos.

- + From 62c5a640b057de7fa5729293227f4c21b0a412fd Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Thu, 20 Oct 2016 16:18:26 -0200 Subject: [PATCH 05/16] Fix qa --- sapl/api/forms.py | 4 +--- sapl/api/pagination.py | 1 - sapl/api/serializers.py | 2 -- sapl/api/urls.py | 3 +-- sapl/api/views.py | 11 +++++------ sapl/base/forms.py | 14 +++++++------- sapl/base/templatetags/menus.py | 3 +-- sapl/base/urls.py | 2 +- sapl/base/views.py | 4 ++-- sapl/comissoes/views.py | 2 +- sapl/compilacao/views.py | 7 +++---- sapl/crud/base.py | 5 ++--- sapl/materia/forms.py | 10 +++++----- sapl/materia/models.py | 2 -- sapl/materia/tests/test_materia.py | 4 ++-- sapl/materia/urls.py | 5 ++--- sapl/materia/views.py | 7 ++----- sapl/parlamentares/views.py | 5 ++--- sapl/protocoloadm/forms.py | 3 +-- sapl/protocoloadm/models.py | 3 +-- sapl/protocoloadm/views.py | 16 ++++++---------- sapl/relatorios/views.py | 2 +- sapl/sessao/models.py | 4 ++-- sapl/sessao/views.py | 1 - sapl/settings.py | 3 +-- sapl/test_urls.py | 7 ++----- sapl/utils.py | 16 +++++++++------- scripts/inicializa_grupos_autorizacoes.py | 1 - 28 files changed, 60 insertions(+), 87 deletions(-) diff --git a/sapl/api/forms.py b/sapl/api/forms.py index 5ac75f00f..fef0952c8 100644 --- a/sapl/api/forms.py +++ b/sapl/api/forms.py @@ -1,11 +1,9 @@ -from django.contrib.contenttypes.fields import GenericRel from django.db.models import Q from django_filters.filters import MethodFilter, ModelChoiceFilter from rest_framework.filters import FilterSet from sapl.base.forms import autores_models_generic_relations from sapl.base.models import Autor, TipoAutor -from sapl.utils import SaplGenericRelation class AutorChoiceFilterSet(FilterSet): @@ -31,7 +29,7 @@ class AutorChoiceFilterSet(FilterSet): order_by = [] for gr in autores_models_generic_relations(): - model = gr[0] + # model = gr[0] sgr = gr[1] for item in sgr: if item.related_model != Autor: diff --git a/sapl/api/pagination.py b/sapl/api/pagination.py index 75941c1d3..bb7096a55 100644 --- a/sapl/api/pagination.py +++ b/sapl/api/pagination.py @@ -1,5 +1,4 @@ from django.core.paginator import EmptyPage -from django.utils.encoding import force_text from rest_framework import pagination from rest_framework.response import Response diff --git a/sapl/api/serializers.py b/sapl/api/serializers.py index 1dc502450..44b6a44e6 100644 --- a/sapl/api/serializers.py +++ b/sapl/api/serializers.py @@ -1,8 +1,6 @@ -from django.contrib.contenttypes.fields import GenericRel from rest_framework import serializers from sapl.base.models import Autor -from sapl.utils import SaplGenericRelation class ChoiceSerializer(serializers.Serializer): diff --git a/sapl/api/urls.py b/sapl/api/urls.py index d87a5d48f..a23984ba7 100644 --- a/sapl/api/urls.py +++ b/sapl/api/urls.py @@ -1,11 +1,10 @@ from django.conf import settings -from django.conf.urls import url, include +from django.conf.urls import include, url from sapl.api.views import AutorListView from .apps import AppConfig - app_name = AppConfig.name diff --git a/sapl/api/views.py b/sapl/api/views.py index 4d5ee0ca8..e33807454 100644 --- a/sapl/api/views.py +++ b/sapl/api/views.py @@ -1,14 +1,13 @@ - from django.db.models import Q from django.http import Http404 from django.utils.translation import ugettext_lazy as _ from rest_framework.filters import DjangoFilterBackend from rest_framework.generics import ListAPIView -from rest_framework.permissions import IsAuthenticated, AllowAny +from rest_framework.permissions import AllowAny, IsAuthenticated from sapl.api.forms import AutorChoiceFilterSet -from sapl.api.serializers import ChoiceSerializer, AutorSerializer,\ - AutorChoiceSerializer +from sapl.api.serializers import (AutorChoiceSerializer, AutorSerializer, + ChoiceSerializer) from sapl.base.models import Autor, TipoAutor from sapl.utils import SaplGenericRelation, sapl_logger @@ -32,7 +31,7 @@ class AutorListView(ListAPIView): em combobox, radiobox, checkbox, etc com pesquisa básica de Autores mas feito para Possíveis Autores armazenados segundo o ContentType associado ao Tipo de Autor via - relacionamento genérico. + relacionamento genérico. Busca feita sem django-filter processada no get_queryset -> processo no cadastro de autores para seleção e busca dos possíveis autores @@ -44,7 +43,7 @@ class AutorListView(ListAPIView): - q - busca textual no nome do Autor ou em fields_search declarados no field SaplGenericRelation das GenericFks - A busca textual acontece via django-filter com a + A busca textual acontece via django-filter com a variável `tr` igual 1 ou 3. Em caso contrário, o django-filter é desativado e a busca é feita no model do ContentType associado ao tipo. diff --git a/sapl/base/forms.py b/sapl/base/forms.py index 08bf8963d..4fcfc4ef7 100644 --- a/sapl/base/forms.py +++ b/sapl/base/forms.py @@ -1,7 +1,7 @@ +import django_filters from crispy_forms.bootstrap import FieldWithButtons, InlineRadios, StrictButton from crispy_forms.helper import FormHelper from crispy_forms.layout import HTML, Button, Div, Field, Fieldset, Layout, Row -from crispy_forms.templatetags.crispy_forms_field import css_class from django import forms from django.conf import settings from django.contrib.auth import get_user_model @@ -13,8 +13,8 @@ from django.contrib.contenttypes.models import ContentType from django.core.exceptions import ValidationError from django.db import models, transaction from django.forms import ModelForm -from django.utils.translation import ugettext_lazy as _, string_concat -import django_filters +from django.utils.translation import ugettext_lazy as _ +from django.utils.translation import string_concat from sapl.base.models import Autor, TipoAutor from sapl.crispy_layout_mixin import (SaplFormLayout, form_actions, to_column, @@ -23,12 +23,11 @@ from sapl.materia.models import MateriaLegislativa from sapl.sessao.models import SessaoPlenaria from sapl.settings import MAX_IMAGE_UPLOAD_SIZE from sapl.utils import (RANGE_ANOS, ImageThumbnailFileInput, - RangeWidgetOverride, autor_label, autor_modal, - SaplGenericRelation) + RangeWidgetOverride, SaplGenericRelation, autor_label, + autor_modal) from .models import AppConfig, CasaLegislativa - ACTION_CREATE_USERS_AUTOR_CHOICE = [ ('C', _('Criar novo Usuário')), ('A', _('Associar um usuário existente')), @@ -181,7 +180,8 @@ class AutorForm(ModelForm): autor_select = Row(to_column(('tipo', 3)), Div(to_column(('nome', 5)), - to_column(('cargo', 4)), css_class="div_nome_cargo"), + to_column(('cargo', 4)), + css_class="div_nome_cargo"), to_column((autor_related, 9)), to_column((Div( Field('autor_related'), diff --git a/sapl/base/templatetags/menus.py b/sapl/base/templatetags/menus.py index 3d208e86b..6e8b4f4a3 100644 --- a/sapl/base/templatetags/menus.py +++ b/sapl/base/templatetags/menus.py @@ -1,11 +1,10 @@ +import yaml from django import template from django.core.urlresolvers import reverse from django.utils.translation import ugettext_lazy as _ -import yaml from sapl.utils import sapl_logger - register = template.Library() diff --git a/sapl/base/urls.py b/sapl/base/urls.py index 4fbda888b..c2a9fdc4a 100644 --- a/sapl/base/urls.py +++ b/sapl/base/urls.py @@ -3,7 +3,7 @@ from django.contrib.auth import views from django.contrib.auth.decorators import permission_required from django.views.generic.base import TemplateView -from sapl.base.views import AutorCrud, TipoAutorCrud, ConfirmarEmailView +from sapl.base.views import AutorCrud, ConfirmarEmailView, TipoAutorCrud from .apps import AppConfig from .forms import LoginForm diff --git a/sapl/base/views.py b/sapl/base/views.py index 3d43d672e..8f0b426aa 100644 --- a/sapl/base/views.py +++ b/sapl/base/views.py @@ -9,12 +9,12 @@ from django.core.urlresolvers import reverse from django.db.models import Count, Q from django.http import HttpResponseRedirect from django.utils.encoding import force_bytes -from django.utils.http import urlsafe_base64_encode, urlsafe_base64_decode +from django.utils.http import urlsafe_base64_decode, urlsafe_base64_encode from django.utils.translation import ugettext_lazy as _ from django.views.generic.base import TemplateView from django_filters.views import FilterView -from sapl.base.forms import AutorForm, TipoAutorForm, AutorFormForAdmin +from sapl.base.forms import AutorForm, AutorFormForAdmin, TipoAutorForm from sapl.base.models import Autor, TipoAutor from sapl.crud.base import CrudAux from sapl.materia.models import MateriaLegislativa, TipoMateriaLegislativa diff --git a/sapl/comissoes/views.py b/sapl/comissoes/views.py index fc679d611..0f767cbea 100644 --- a/sapl/comissoes/views.py +++ b/sapl/comissoes/views.py @@ -3,7 +3,7 @@ from django.core.urlresolvers import reverse from django.db.models import F from django.views.generic import ListView -from sapl.crud.base import Crud, CrudAux, MasterDetailCrud, RP_DETAIL, RP_LIST +from sapl.crud.base import RP_DETAIL, RP_LIST, Crud, CrudAux, MasterDetailCrud from sapl.materia.models import MateriaLegislativa, Tramitacao from .models import (CargoComissao, Comissao, Composicao, Participacao, diff --git a/sapl/compilacao/views.py b/sapl/compilacao/views.py index ccafcb6c2..9b7f79d95 100644 --- a/sapl/compilacao/views.py +++ b/sapl/compilacao/views.py @@ -1,7 +1,7 @@ -from collections import OrderedDict -from datetime import datetime, timedelta import logging import sys +from collections import OrderedDict +from datetime import datetime, timedelta from braces.views import FormMessagesMixin from django import forms @@ -20,8 +20,8 @@ from django.shortcuts import get_object_or_404, redirect from django.utils.dateparse import parse_date from django.utils.decorators import method_decorator from django.utils.encoding import force_text -from django.utils.translation import string_concat from django.utils.translation import ugettext_lazy as _ +from django.utils.translation import string_concat from django.views.generic.base import TemplateView from django.views.generic.detail import DetailView from django.views.generic.edit import (CreateView, DeleteView, FormView, @@ -49,7 +49,6 @@ from sapl.compilacao.utils import (DISPOSITIVO_SELECT_RELATED, from sapl.crud.base import Crud, CrudListView, make_pagination from sapl.settings import BASE_DIR - TipoNotaCrud = Crud.build(TipoNota, 'tipo_nota') TipoVideCrud = Crud.build(TipoVide, 'tipo_vide') TipoPublicacaoCrud = Crud.build(TipoPublicacao, 'tipo_publicacao') diff --git a/sapl/crud/base.py b/sapl/crud/base.py index 694898115..55366bcc5 100644 --- a/sapl/crud/base.py +++ b/sapl/crud/base.py @@ -14,8 +14,8 @@ from django.db.models.fields.related import ForeignKey from django.http.response import Http404 from django.utils.decorators import classonlymethod from django.utils.encoding import force_text -from django.utils.translation import string_concat from django.utils.translation import ugettext_lazy as _ +from django.utils.translation import string_concat from django.views.generic import (CreateView, DeleteView, DetailView, ListView, UpdateView) from django.views.generic.base import ContextMixin @@ -25,7 +25,6 @@ from sapl.crispy_layout_mixin import CrispyLayoutFormMixin, get_field_display from sapl.settings import BASE_DIR from sapl.utils import normalize - logger = logging.getLogger(BASE_DIR.name) ACTION_LIST, ACTION_CREATE, ACTION_DETAIL, ACTION_UPDATE, ACTION_DELETE = \ @@ -1287,7 +1286,7 @@ class MasterDetailCrud(Crud): if hasattr(obj, 'parent_field'): parent_field = obj.parent_field.split('__') if not obj.is_m2m or len(parent_field) > 1: - field = self.model._meta.get_field(parent_field[0]) + # field = self.model._meta.get_field(parent_field[0]) if isinstance(getattr( self.object, parent_field[0]), models.Model): diff --git a/sapl/materia/forms.py b/sapl/materia/forms.py index 26f14a64b..2a7f5bb92 100644 --- a/sapl/materia/forms.py +++ b/sapl/materia/forms.py @@ -1,5 +1,6 @@ from datetime import datetime +import django_filters from crispy_forms.helper import FormHelper from crispy_forms.layout import HTML, Button, Column, Fieldset, Layout from django import forms @@ -8,7 +9,6 @@ from django.db import models from django.db.models import Max from django.forms import ModelForm from django.utils.translation import ugettext_lazy as _ -import django_filters from sapl.base.models import Autor from sapl.comissoes.models import Comissao @@ -20,10 +20,10 @@ from sapl.settings import MAX_DOC_UPLOAD_SIZE from sapl.utils import (RANGE_ANOS, RangeWidgetOverride, autor_label, autor_modal) -from .models import (AcompanhamentoMateria, Anexada, Autoria, - DespachoInicial, DocumentoAcessorio, MateriaLegislativa, - Numeracao, Proposicao, Relatoria, TipoMateriaLegislativa, - Tramitacao, UnidadeTramitacao) +from .models import (AcompanhamentoMateria, Anexada, Autoria, DespachoInicial, + DocumentoAcessorio, MateriaLegislativa, Numeracao, + Proposicao, Relatoria, TipoMateriaLegislativa, Tramitacao, + UnidadeTramitacao) def ANO_CHOICES(): diff --git a/sapl/materia/models.py b/sapl/materia/models.py index e326b7698..be92e9063 100644 --- a/sapl/materia/models.py +++ b/sapl/materia/models.py @@ -7,10 +7,8 @@ from sapl.base.models import Autor from sapl.comissoes.models import Comissao from sapl.parlamentares.models import Parlamentar from sapl.utils import (RANGE_ANOS, YES_NO_CHOICES, - get_settings_auth_user_model, restringe_tipos_de_arquivo_txt) - EM_TRAMITACAO = [(1, 'Sim'), (0, 'Não')] diff --git a/sapl/materia/tests/test_materia.py b/sapl/materia/tests/test_materia.py index ed6ae1ccd..db5dd7684 100644 --- a/sapl/materia/tests/test_materia.py +++ b/sapl/materia/tests/test_materia.py @@ -1,10 +1,10 @@ +import pytest from django.contrib.auth import get_user_model from django.core.files.uploadedfile import SimpleUploadedFile from django.core.urlresolvers import reverse from model_mommy import mommy -import pytest -from sapl.base.models import TipoAutor, Autor +from sapl.base.models import Autor, TipoAutor from sapl.comissoes.models import Comissao, TipoComissao from sapl.materia.models import (Anexada, Autoria, DespachoInicial, DocumentoAcessorio, MateriaLegislativa, diff --git a/sapl/materia/urls.py b/sapl/materia/urls.py index 5400978c6..c78796569 100644 --- a/sapl/materia/urls.py +++ b/sapl/materia/urls.py @@ -3,9 +3,8 @@ from django.conf.urls import include, url from sapl.materia.views import (AcompanhamentoConfirmarView, AcompanhamentoExcluirView, AcompanhamentoMateriaView, AnexadaCrud, - AutoriaCrud, - ConfirmarProposicao, DespachoInicialCrud, - DocumentoAcessorioCrud, + AutoriaCrud, ConfirmarProposicao, + DespachoInicialCrud, DocumentoAcessorioCrud, DocumentoAcessorioEmLoteView, LegislacaoCitadaCrud, MateriaLegislativaCrud, MateriaLegislativaPesquisaView, MateriaTaView, diff --git a/sapl/materia/views.py b/sapl/materia/views.py index 7cd83a2ea..a85bdeb5f 100644 --- a/sapl/materia/views.py +++ b/sapl/materia/views.py @@ -5,7 +5,6 @@ from string import ascii_letters, digits from crispy_forms.helper import FormHelper from crispy_forms.layout import HTML from django.contrib import messages -from django.contrib.auth import get_user_model from django.contrib.auth.mixins import PermissionRequiredMixin from django.core.exceptions import MultipleObjectsReturned, ObjectDoesNotExist from django.core.mail import send_mail @@ -15,7 +14,6 @@ from django.http import JsonResponse from django.http.response import HttpResponseRedirect from django.shortcuts import redirect from django.template import Context, loader -from django.utils.http import urlsafe_base64_decode from django.utils.translation import ugettext_lazy as _ from django.views.generic import CreateView, ListView, TemplateView, UpdateView from django.views.generic.base import RedirectView @@ -33,10 +31,9 @@ from sapl.materia.forms import AnexadaForm, LegislacaoCitadaForm from sapl.norma.models import LegislacaoCitada from sapl.utils import (TURNO_TRAMITACAO_CHOICES, YES_NO_CHOICES, autor_label, autor_modal, gerar_hash_arquivo, get_base_url, + montar_row_autor, permission_required_for_app, permissoes_autor, permissoes_materia, - permissoes_protocoloadm, permission_required_for_app, - montar_row_autor) - + permissoes_protocoloadm) from .forms import (AcessorioEmLoteFilterSet, AcompanhamentoMateriaForm, ConfirmarProposicaoForm, DocumentoAcessorioForm, diff --git a/sapl/parlamentares/views.py b/sapl/parlamentares/views.py index d31e4557d..4e937bd54 100644 --- a/sapl/parlamentares/views.py +++ b/sapl/parlamentares/views.py @@ -12,9 +12,8 @@ from sapl.crud.base import (RP_CHANGE, RP_DETAIL, RP_LIST, Crud, CrudAux, from sapl.materia.models import Proposicao, Relatoria from sapl.parlamentares.apps import AppConfig -from .forms import (FiliacaoForm, LegislaturaCreateForm, - LegislaturaUpdateForm, ParlamentarCreateForm, - ParlamentarForm) +from .forms import (FiliacaoForm, LegislaturaCreateForm, LegislaturaUpdateForm, + ParlamentarCreateForm, ParlamentarForm) from .models import (CargoMesa, Coligacao, ComposicaoColigacao, ComposicaoMesa, Dependente, Filiacao, Frente, Legislatura, Mandato, NivelInstrucao, Parlamentar, Partido, SessaoLegislativa, diff --git a/sapl/protocoloadm/forms.py b/sapl/protocoloadm/forms.py index 7eae4909d..549cdc498 100644 --- a/sapl/protocoloadm/forms.py +++ b/sapl/protocoloadm/forms.py @@ -1,5 +1,6 @@ from datetime import datetime +import django_filters from crispy_forms.bootstrap import InlineRadios from crispy_forms.helper import FormHelper from crispy_forms.layout import HTML, Button, Fieldset, Layout, Submit @@ -8,7 +9,6 @@ from django.core.exceptions import ObjectDoesNotExist, ValidationError from django.db import models from django.forms import ModelForm from django.utils.translation import ugettext_lazy as _ -import django_filters from sapl.base.models import Autor from sapl.crispy_layout_mixin import form_actions, to_row @@ -20,7 +20,6 @@ from .models import (DocumentoAcessorioAdministrativo, DocumentoAdministrativo, Protocolo, TipoDocumentoAdministrativo, TramitacaoAdministrativo) - TIPOS_PROTOCOLO = [('0', 'Enviado'), ('1', 'Recebido'), ('', 'Ambos')] NATUREZA_PROCESSO = [('', 'Ambos'), diff --git a/sapl/protocoloadm/models.py b/sapl/protocoloadm/models.py index 5f713202b..4ec3393ed 100644 --- a/sapl/protocoloadm/models.py +++ b/sapl/protocoloadm/models.py @@ -5,8 +5,7 @@ from django.utils.translation import ugettext_lazy as _ from model_utils import Choices from sapl.base.models import Autor -from sapl.materia.models import (TipoMateriaLegislativa, - UnidadeTramitacao) +from sapl.materia.models import TipoMateriaLegislativa, UnidadeTramitacao from sapl.utils import RANGE_ANOS, YES_NO_CHOICES diff --git a/sapl/protocoloadm/views.py b/sapl/protocoloadm/views.py index 30a9606fa..8a52c1e38 100644 --- a/sapl/protocoloadm/views.py +++ b/sapl/protocoloadm/views.py @@ -1,13 +1,11 @@ from datetime import date, datetime -import json from braces.views import FormValidMessageMixin from django.contrib import messages from django.contrib.auth.mixins import PermissionRequiredMixin -from django.core.exceptions import ObjectDoesNotExist from django.core.urlresolvers import reverse -from django.db.models import Max, Q -from django.http import HttpResponse, HttpResponseRedirect +from django.db.models import Max +from django.http import HttpResponseRedirect from django.shortcuts import redirect from django.utils.translation import ugettext_lazy as _ from django.views.generic import CreateView, DetailView, FormView, ListView @@ -15,7 +13,7 @@ from django.views.generic.base import TemplateView from django_filters.views import FilterView from sapl.base.apps import AppConfig as AppsAppConfig -from sapl.base.models import AppConfig, Autor +from sapl.base.models import AppConfig from sapl.crud.base import Crud, CrudAux, MasterDetailCrud, make_pagination from sapl.materia.models import TipoMateriaLegislativa from sapl.utils import (create_barcode, get_client_ip, permissoes_adm, @@ -26,12 +24,10 @@ from .forms import (AnularProcoloAdmForm, DocumentoAcessorioAdministrativoForm, DocumentoAdministrativoForm, ProtocoloDocumentForm, ProtocoloFilterSet, ProtocoloMateriaForm, TramitacaoAdmEditForm, TramitacaoAdmForm) -from .models import (DocumentoAcessorioAdministrativo, - DocumentoAdministrativo, Protocolo, - StatusTramitacaoAdministrativo, +from .models import (DocumentoAcessorioAdministrativo, DocumentoAdministrativo, + Protocolo, StatusTramitacaoAdministrativo, TipoDocumentoAdministrativo, TramitacaoAdministrativo) - TipoDocumentoAdministrativoCrud = CrudAux.build( TipoDocumentoAdministrativo, '') @@ -634,4 +630,4 @@ def pesquisa_autores(request): sort_keys=True, ensure_ascii=False), content_type="application/json; charset=utf-8") -""" \ No newline at end of file +""" diff --git a/sapl/relatorios/views.py b/sapl/relatorios/views.py index 6c3184b42..82fd7edf7 100644 --- a/sapl/relatorios/views.py +++ b/sapl/relatorios/views.py @@ -4,7 +4,7 @@ from bs4 import BeautifulSoup from django.http import Http404, HttpResponse from django.utils.translation import ugettext_lazy as _ -from sapl.base.models import CasaLegislativa, Autor +from sapl.base.models import Autor, CasaLegislativa from sapl.comissoes.models import Comissao from sapl.materia.models import (Autoria, MateriaLegislativa, Numeracao, Tramitacao, UnidadeTramitacao) diff --git a/sapl/sessao/models.py b/sapl/sessao/models.py index dc375fff7..cf74399b5 100644 --- a/sapl/sessao/models.py +++ b/sapl/sessao/models.py @@ -6,8 +6,8 @@ from sapl.base.models import Autor from sapl.materia.models import MateriaLegislativa from sapl.parlamentares.models import (CargoMesa, Legislatura, Parlamentar, Partido, SessaoLegislativa) -from sapl.utils import YES_NO_CHOICES, restringe_tipos_de_arquivo_txt,\ - SaplGenericRelation +from sapl.utils import (YES_NO_CHOICES, SaplGenericRelation, + restringe_tipos_de_arquivo_txt) class CargoBancada(models.Model): diff --git a/sapl/sessao/views.py b/sapl/sessao/views.py index 3f8fe93af..fbd044b51 100644 --- a/sapl/sessao/views.py +++ b/sapl/sessao/views.py @@ -45,7 +45,6 @@ from .models import (Bancada, Bloco, CargoBancada, CargoMesa, SessaoPlenariaPresenca, TipoExpediente, TipoResultadoVotacao, TipoSessaoPlenaria, VotoParlamentar) - TipoSessaoCrud = CrudAux.build(TipoSessaoPlenaria, 'tipo_sessao_plenaria') TipoExpedienteCrud = CrudAux.build(TipoExpediente, 'tipo_expediente') CargoBancadaCrud = CrudAux.build(CargoBancada, '') diff --git a/sapl/settings.py b/sapl/settings.py index f3030d255..7f39005b4 100644 --- a/sapl/settings.py +++ b/sapl/settings.py @@ -23,7 +23,6 @@ from unipath import Path from .temp_suppress_crispy_form_warnings import \ SUPRESS_CRISPY_FORM_WARNINGS_LOGGING - BASE_DIR = Path(__file__).ancestor(1) PROJECT_DIR = Path(__file__).ancestor(2) @@ -98,7 +97,7 @@ MIDDLEWARE_CLASSES = ( REST_FRAMEWORK = { "DEFAULT_RENDERER_CLASSES": ( "rest_framework.renderers.JSONRenderer", - #"rest_framework.renderers.BrowsableAPIRenderer", + # "rest_framework.renderers.BrowsableAPIRenderer", ), "DEFAULT_PARSER_CLASSES": ( "rest_framework.parsers.JSONParser", diff --git a/sapl/test_urls.py b/sapl/test_urls.py index 02be7505c..51c6f5e2e 100644 --- a/sapl/test_urls.py +++ b/sapl/test_urls.py @@ -1,22 +1,19 @@ +import pytest from django.apps import apps from django.contrib.auth import get_user_model from django.contrib.auth.management import _get_all_permissions from django.contrib.auth.models import Permission from django.contrib.contenttypes.models import ContentType from django.db import transaction -from django.utils.translation import string_concat -from django.utils.translation import string_concat from django.utils.translation import ugettext_lazy as _ -import pytest +from django.utils.translation import string_concat from sapl.crud.base import PermissionRequiredForAppCrudMixin -from sapl.materia.views import recuperar_materia from scripts.inicializa_grupos_autorizacoes import cria_grupos_permissoes from scripts.lista_urls import lista_urls from .settings import SAPL_APPS - pytestmark = pytest.mark.django_db sapl_appconfs = [apps.get_app_config(n[5:]) for n in SAPL_APPS] diff --git a/sapl/utils.py b/sapl/utils.py index 7029a508b..b4e6450fa 100644 --- a/sapl/utils.py +++ b/sapl/utils.py @@ -1,9 +1,10 @@ +import hashlib +import logging from datetime import date from functools import wraps from unicodedata import normalize as unicodedata_normalize -import hashlib -import logging +import magic from crispy_forms.helper import FormHelper from crispy_forms.layout import HTML, Button from django import forms @@ -17,11 +18,10 @@ from django.contrib.contenttypes.models import ContentType from django.core.exceptions import PermissionDenied, ValidationError from django.utils.translation import ugettext_lazy as _ from floppyforms import ClearableFileInput + from sapl.crispy_layout_mixin import SaplFormLayout, form_actions, to_row -import magic from sapl.settings import BASE_DIR - sapl_logger = logging.getLogger(BASE_DIR.name) @@ -121,8 +121,10 @@ class SaplGenericRelation(GenericRelation): ) - [ref_1]: https://docs.djangoproject.com/el/1.10/topics/db/queries/#field-lookups - [ref_2]: https://github.com/interlegis/sapl/blob/master/sapl/parlamentares/models.py + [ref_1]: https://docs.djangoproject.com/el/1.10/topics/db/queries/ + #field-lookups + [ref_2]: https://github.com/interlegis/sapl/blob/master/sapl/ + parlamentares/models.py """ def __init__(self, to, fields_search=(), **kwargs): @@ -136,7 +138,7 @@ class SaplGenericRelation(GenericRelation): for field in fields_search: # descomente para ver todas os campos que são elementos de busca - #print(kwargs['related_query_name'], field) + # print(kwargs['related_query_name'], field) assert isinstance(field, (tuple, list)), _( 'fields_search deve ser um array de tuplas ou listas.') diff --git a/scripts/inicializa_grupos_autorizacoes.py b/scripts/inicializa_grupos_autorizacoes.py index fe69914b1..38606b0a3 100644 --- a/scripts/inicializa_grupos_autorizacoes.py +++ b/scripts/inicializa_grupos_autorizacoes.py @@ -10,7 +10,6 @@ if True: from django.contrib.auth import get_user_model from django.contrib.auth.models import Group, Permission from django.contrib.contenttypes.models import ContentType - from sapl.base.models import Autor class InicializaGruposAutorizacoes(): From ff576f8cfdecc6d24860d0b2dda6919a65eb3a28 Mon Sep 17 00:00:00 2001 From: Eduardo Calil Date: Thu, 20 Oct 2016 17:39:37 -0200 Subject: [PATCH 06/16] =?UTF-8?q?Trata=20o=20caso=20em=20que=20a=20sess?= =?UTF-8?q?=C3=A3o=20do=20relat=C3=B3rio=20n=C3=A3o=20existe?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/relatorios/views.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/sapl/relatorios/views.py b/sapl/relatorios/views.py index 82fd7edf7..2900ee9a8 100644 --- a/sapl/relatorios/views.py +++ b/sapl/relatorios/views.py @@ -1,6 +1,8 @@ from datetime import datetime from bs4 import BeautifulSoup + +from django.core.exceptions import ObjectDoesNotExist from django.http import Http404, HttpResponse from django.utils.translation import ugettext_lazy as _ @@ -783,7 +785,10 @@ def relatorio_sessao_plenaria(request, pk): rodape = get_rodape(casa) imagem = get_imagem(casa) - sessao = SessaoPlenaria.objects.get(id=pk) + try: + sessao = SessaoPlenaria.objects.get(id=pk) + except ObjectDoesNotExist: + raise Http404('Essa página não existe') (inf_basicas_dic, lst_mesa, From 0ae9ccaa18bb8a44d434fb623d5dd6a02e32fd3a Mon Sep 17 00:00:00 2001 From: Edward Ribeiro Date: Thu, 20 Oct 2016 17:38:41 -0200 Subject: [PATCH 07/16] =?UTF-8?q?HOT-FIX:=20conserta=20erro=20de=20convers?= =?UTF-8?q?=C3=A3o=20(iso=20->=20unicode)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/relatorios/templates/pdf_espelho_preparar_pysc.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sapl/relatorios/templates/pdf_espelho_preparar_pysc.py b/sapl/relatorios/templates/pdf_espelho_preparar_pysc.py index 6dc4a8662..425d8db0c 100644 --- a/sapl/relatorios/templates/pdf_espelho_preparar_pysc.py +++ b/sapl/relatorios/templates/pdf_espelho_preparar_pysc.py @@ -60,7 +60,7 @@ if REQUEST.txt_check=='1': REQUEST=context.REQUEST for materia in context.zsql.materia_obter_zsql(cod_materia=cod_mat): dic={} - dic['titulo']="INDICAÇÃO: "+str(materia.num_ident_basica)+" "+str(materia.ano_ident_basica) + dic['titulo']="INDICAÇÃO: "+str(materia.num_ident_basica)+" "+str(materia.ano_ident_basica) dic['materia']=str(materia.num_ident_basica)+"/"+str(materia.ano_ident_basica) dic['dat_apresentacao']=materia.dat_apresentacao dic['txt_ementa']=materia.txt_ementa From f6706a8898c5d2a7a1a235305d25fa270bd28888 Mon Sep 17 00:00:00 2001 From: Edward Date: Thu, 20 Oct 2016 17:52:12 -0200 Subject: [PATCH 08/16] =?UTF-8?q?Apagando=20arquivo=20desnecess=C3=A1rio?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Remove 'echo'. --- echo | 14029 --------------------------------------------------------- 1 file changed, 14029 deletions(-) delete mode 100644 echo diff --git a/echo b/echo deleted file mode 100644 index 7a95a6562..000000000 --- a/echo +++ /dev/null @@ -1,14029 +0,0 @@ -]0;IPython: Documents/saplVIRTUAL_ENV -> /home/eduardo/.virtualenvs/sapl/lib/python3.4/site-packages -============================= test session starts ============================== -platform linux -- Python 3.4.3, pytest-2.9.2, py-1.4.31, pluggy-0.3.1 -django settings: sapl.settings (from ini file) -rootdir: /home/eduardo/Documents/sapl, inifile: pytest.ini -plugins: cov-2.3.0, django-2.9.1, ipdb-0.1-prerelease2 -collected 2013 items - -sapl/test_urls.py .....................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................................F....F....F....F....F....F.........F....F....F....F....F....F....F....F.........F....F....F....F....F....F....F....F....F....F....F....F....F....F....F....F....F....F....F...........F....F....F....F....F..............................................................................FFFFFFFFFFFFFFFFFFF................................................................................................................................................................................................................................................................................................................................................................................................................FFFFFFFFFF.............................................................FFFFFF.FFF.FFFFFFFFFFFFFFFFFFFFFFF..F - -=================================== FAILURES =================================== -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item238] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050365a60>, 'sistema/app-config/', [], 'sapl.base') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item243] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04ec17bf8>, 'sistema/bancada/', [], 'sapl.sessao') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item248] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04ec17ea0>, 'sistema/bloco/', [], 'sapl.sessao') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item253] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04ec201e0>, 'sistema/cargo-bancada/', [], 'sapl.sessao') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item258] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0503657b8>, 'sistema/casa-legislativa/', [], 'sapl.base') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item263] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9c6620>, 'sistema/coligacao/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item273] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036cb70>, 'sistema/comissao/cargo/', [], 'sapl.comissoes') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item278] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036ce18>, 'sistema/comissao/periodo-composicao/', [], 'sapl.comissoes') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item283] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050378158>, 'sistema/comissao/tipo/', [], 'sapl.comissoes') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item288] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9c6b70>, 'sistema/frente/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item293] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502df488>, 'sistema/lexml/provedor/', [], 'sapl.lexml') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item298] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502df730>, 'sistema/lexml/publicador/', [], 'sapl.lexml') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item303] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9f0bf8>, 'sistema/materia/autor/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item308] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9f91e0>, 'sistema/materia/orgao/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item318] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9e5b70>, 'sistema/materia/regime-tramitacao/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item323] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9f0ea0>, 'sistema/materia/status-tramitacao/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item328] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9e5e18>, 'sistema/materia/tipo-autor/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item333] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9f0158>, 'sistema/materia/tipo-documento/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item338] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9f0400>, 'sistema/materia/tipo-fim-relatoria/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item343] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9e58c8>, 'sistema/materia/tipo/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item348] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9f06a8>, 'sistema/materia/unidade-tramitacao/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item353] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9d91e0>, 'sistema/mesa-diretora/cargo-mesa/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item358] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9cfea0>, 'sistema/mesa-diretora/sessao-legislativa/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item363] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9fd510>, 'sistema/norma/assunto/', [], 'sapl.norma') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item368] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9fd268>, 'sistema/norma/tipo/', [], 'sapl.norma') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item373] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9c6e18>, 'sistema/parlamentar/legislatura/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item378] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9cf400>, 'sistema/parlamentar/nivel-instrucao/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item383] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9cfbf8>, 'sistema/parlamentar/partido/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item388] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9cf6a8>, 'sistema/parlamentar/tipo-afastamento/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item393] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9cf158>, 'sistema/parlamentar/tipo-dependente/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item398] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9cf950>, 'sistema/parlamentar/tipo-militar/', [], 'sapl.parlamentares') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item403] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9e5620>, 'sistema/proposicao/autor/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item408] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9e5378>, 'sistema/proposicao/tipo/', [], 'sapl.materia') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item420] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04ec17950>, 'sistema/sessao-plenaria/tipo-expediente/', [], 'sapl.sessao') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item425] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04ec176a8>, 'sistema/sessao-plenaria/tipo-resultado-votacao/', [], 'sapl.sessao') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item430] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04ec17400>, 'sistema/sessao-plenaria/tipo/', [], 'sapl.sessao') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item435] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e400>, 'sistema/status-tramitacao-adm/', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -________ test_crudaux_list_do_crud_esta_na_pagina_sistema[url_item440] _________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e158>, 'sistema/tipo-documento-adm/', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_crudaux_list_do_crud_esta_na_pagina_sistema(url_item, admin_client): - - # Verifica a url é de um CrudAux e, se for, testa se está - # na página Tabelas Auxiliares - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - view_class = None - if hasattr(key, 'view_class'): - view_class = key.view_class - - # se não tem view_class, possivelmente não é uma classed base view - if not view_class: - return - - # se não tem atributo crud, não é será nenhum tipo de crud - if not hasattr(view_class, 'crud'): - return - - herancas_crud = list(map(str, type.mro(view_class.crud))) - for string_class in herancas_crud: - if 'CrudAux' in string_class: - - herancas_view = list(map(str, type.mro(view_class))) - - for string_view_class in herancas_view: - # verifica se o link para manutenção do crud está em /sistema - if 'ListView' in string_view_class: -> response = admin_client.get('/sistema', {}, follow=True) - -sapl/test_urls.py:141: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError -_________________________ test_urlpatterns[url_item16] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9d9510>, 'docadm/', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item17] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98fd90>, 'docadm/%(pk)s', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item18] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98fea0>, 'docadm/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/1/delete) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item19] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98fe18>, 'docadm/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/1/edit) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item20] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9d97b8>, 'docadm/create', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/create) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item21] _________________________ - -url_item = (, 'docadm/doc-ace-adm/%(pk)s', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-ace-adm/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item22] _________________________ - -url_item = (, 'docadm/doc-ace-adm/edit/%(pk)s/%(ano)s', ['pk', 'ano'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-ace-adm/edit/1/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item23] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98ff28>, 'docadm/doc-acessorio/', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-acessorio/) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item24] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502800d0>, 'docadm/doc-acessorio/%(pk)s', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-acessorio/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item25] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502801e0>, 'docadm/doc-acessorio/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-acessorio/1/delete) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item26] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280158>, 'docadm/doc-acessorio/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-acessorio/1/edit) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item27] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280048>, 'docadm/doc-acessorio/create', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-acessorio/create) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item28] _________________________ - -url_item = (, 'docadm/doc-adm/%(pk)s', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/doc-adm/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item29] _________________________ - -url_item = (, 'docadm/pesq-doc-adm', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/pesq-doc-adm) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item30] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280268>, 'docadm/tramitacao-doc-adm/%(pk)s/tramitacaoadministrativo', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/tramitacao-doc-adm/1/tramitacaoadministrativo) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item31] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502802f0>, 'docadm/tramitacao-doc-adm/%(pk)s/tramitacaoadministrativo/create', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/tramitacao-doc-adm/1/tramitacaoadministrativo/create) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item32] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280378>, 'docadm/tramitacao-doc-adm/tramitacaoadministrativo/%(pk)s', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/tramitacao-doc-adm/tramitacaoadministrativo/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item33] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280488>, 'docadm/tramitacao-doc-adm/tramitacaoadministrativo/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/tramitacao-doc-adm/tramitacaoadministrativo/1/delete) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -_________________________ test_urlpatterns[url_item34] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280400>, 'docadm/tramitacao-doc-adm/tramitacaoadministrativo/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/docadm/tramitacao-doc-adm/tramitacaoadministrativo/1/edit) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item435] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e400>, 'sistema/status-tramitacao-adm/', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/status-tramitacao-adm/) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item436] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e510>, 'sistema/status-tramitacao-adm/%(pk)s', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/status-tramitacao-adm/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item437] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e620>, 'sistema/status-tramitacao-adm/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/status-tramitacao-adm/1/delete) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item438] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e598>, 'sistema/status-tramitacao-adm/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/status-tramitacao-adm/1/edit) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item439] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e488>, 'sistema/status-tramitacao-adm/create', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/status-tramitacao-adm/create) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item440] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e158>, 'sistema/tipo-documento-adm/', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/tipo-documento-adm/) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item441] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e268>, 'sistema/tipo-documento-adm/%(pk)s', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/tipo-documento-adm/1) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item442] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e378>, 'sistema/tipo-documento-adm/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/tipo-documento-adm/1/delete) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item443] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e2f0>, 'sistema/tipo-documento-adm/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/tipo-documento-adm/1/edit) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -________________________ test_urlpatterns[url_item444] _________________________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f91e1e0>, 'sistema/tipo-documento-adm/create', [], 'sapl.protocoloadm') -admin_client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_urlpatterns(url_item, admin_client): - - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - assert '\n' not in url, """ - A url (%s) da app (%s) está mal formada. - """ % (app_name, url) - - app_name = app_name[5:] - - assert app_name in apps_url_patterns_prefixs_and_users, """ - A app (%s) da url (%s) não consta na lista de prefixos do teste - """ % (app_name, url) - - if app_name in apps_url_patterns_prefixs_and_users: - prefixs = apps_url_patterns_prefixs_and_users[app_name]['prefixs'] - - isvalid = False - for prefix in prefixs: - if url.startswith(prefix): - isvalid = True - break - -> assert isvalid, """ - O prefixo da url (%s) não está no padrão de sua app (%s). - Os prefixos permitidos são: - %s - """ % (url, app_name, prefixs) -E AssertionError: -E O prefixo da url (/sistema/tipo-documento-adm/create) não está no padrão de sua app (protocoloadm). -E Os prefixos permitidos são: -E ['/protocoloadm', '/docadm/sistema'] -E -E assert False - -sapl/test_urls.py:254: AssertionError -______________ test_permissions_urls_for_users_by_apps[url_item3] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c620>, 'comissao/%(pk)s/composicao/create', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('7bpa3uesppy7ns1gsx9sm5lcsnyo5hn3', datetime.datetime(2016, 10, 11, 14, 15, 15, 423886, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/1/composicao/create -______________ test_permissions_urls_for_users_by_apps[url_item4] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c510>, 'comissao/%(pk)s/delete', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_geral {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/1/delete -______________ test_permissions_urls_for_users_by_apps[url_item5] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c488>, 'comissao/%(pk)s/edit', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('7jt6whgolvs7ftcx9yzp2xave7o5xvnt', datetime.datetime(2016, 10, 11, 14, 15, 19, 387079, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/1/edit -______________ test_permissions_urls_for_users_by_apps[url_item6] ______________ - -url_item = (, 'comissao/%(pk)s/materias-em-tramitacao', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/1/materias-em-tramitacao -______________ test_permissions_urls_for_users_by_apps[url_item7] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c840>, 'comissao/%(pk)s/participacao', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('blz7if1xg2odotvm7i641shbhcp3mxq4', datetime.datetime(2016, 10, 11, 14, 15, 22, 611850, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_painel {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/1/participacao -______________ test_permissions_urls_for_users_by_apps[url_item8] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c8c8>, 'comissao/%(pk)s/participacao/create', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('l9rjsnqyvvtkqoqjc3mhledk1q9rl7hr', datetime.datetime(2016, 10, 11, 14, 15, 24, 382486, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/1/participacao/create -_____________ test_permissions_urls_for_users_by_apps[url_item10] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c7b8>, 'comissao/composicao/%(pk)s/delete', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('u14b676mus329iqw81o8l3rcqlgnj6q9', datetime.datetime(2016, 10, 11, 14, 15, 27, 591360, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/composicao/1/delete -_____________ test_permissions_urls_for_users_by_apps[url_item11] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c730>, 'comissao/composicao/%(pk)s/edit', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('rq6fh5ia0ac9v4gzdoz1vcv7kabco7wt', datetime.datetime(2016, 10, 11, 14, 15, 29, 342310, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/composicao/1/edit -_____________ test_permissions_urls_for_users_by_apps[url_item12] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c378>, 'comissao/create', [], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('p0viey88gte42ifykp8uw4lijujkgryx', datetime.datetime(2016, 10, 11, 14, 15, 31, 253921, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/create -_____________ test_permissions_urls_for_users_by_apps[url_item14] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036ca60>, 'comissao/participacao/%(pk)s/delete', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('n1ponlaf0agb3hqg6ie1fj6cy42qkm0y', datetime.datetime(2016, 10, 11, 14, 15, 34, 667815, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/participacao/1/delete -_____________ test_permissions_urls_for_users_by_apps[url_item15] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc05036c9d8>, 'comissao/participacao/%(pk)s/edit', ['pk'], 'sapl.comissoes') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('bpl6gfizvrbeymgz036oiuc91hkxq5dk', datetime.datetime(2016, 10, 11, 14, 15, 37, 451057, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_comissoes': ['/comissao'], 'operador_geral': ['/sistema', '/comissao']} /comissao/participacao/1/edit -_____________ test_permissions_urls_for_users_by_apps[url_item16] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9d9510>, 'docadm/', [], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('fz8bb6icn6cdi0wz8wlx3hn1prkgb75v', datetime.datetime(2016, 10, 11, 14, 15, 40, 286646, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/ -_____________ test_permissions_urls_for_users_by_apps[url_item17] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98fd90>, 'docadm/%(pk)s', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/1 -_____________ test_permissions_urls_for_users_by_apps[url_item18] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98fea0>, 'docadm/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/1/delete -_____________ test_permissions_urls_for_users_by_apps[url_item19] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98fe18>, 'docadm/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/1/edit -_____________ test_permissions_urls_for_users_by_apps[url_item20] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f9d97b8>, 'docadm/create', [], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('jlcqaw2862k14g7peuhvw4jdiikkqlwj', datetime.datetime(2016, 10, 11, 14, 15, 48, 562375, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/create -_____________ test_permissions_urls_for_users_by_apps[url_item21] ______________ - -url_item = (, 'docadm/doc-ace-adm/%(pk)s', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('68us1rdd3hs8t1a7jxfl2ujqzl2h5zq1', datetime.datetime(2016, 10, 11, 14, 15, 50, 180925, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-ace-adm/1 -_____________ test_permissions_urls_for_users_by_apps[url_item22] ______________ - -url_item = (, 'docadm/doc-ace-adm/edit/%(pk)s/%(ano)s', ['pk', 'ano'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-ace-adm/edit/1/1 -_____________ test_permissions_urls_for_users_by_apps[url_item23] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc04f98ff28>, 'docadm/doc-acessorio/', [], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('3khibaw474loj6q1g2j5j97gwkms2pza', datetime.datetime(2016, 10, 11, 14, 15, 54, 101230, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-acessorio/ -_____________ test_permissions_urls_for_users_by_apps[url_item24] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502800d0>, 'docadm/doc-acessorio/%(pk)s', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-acessorio/1 -_____________ test_permissions_urls_for_users_by_apps[url_item25] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502801e0>, 'docadm/doc-acessorio/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-acessorio/1/delete -_____________ test_permissions_urls_for_users_by_apps[url_item26] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280158>, 'docadm/doc-acessorio/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-acessorio/1/edit -_____________ test_permissions_urls_for_users_by_apps[url_item27] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280048>, 'docadm/doc-acessorio/create', [], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('xhve3xe2zi66umdru23jg4ycic21mz5v', datetime.datetime(2016, 10, 11, 14, 16, 4, 514192, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-acessorio/create -_____________ test_permissions_urls_for_users_by_apps[url_item28] ______________ - -url_item = (, 'docadm/doc-adm/%(pk)s', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/doc-adm/1 -_____________ test_permissions_urls_for_users_by_apps[url_item29] ______________ - -url_item = (, 'docadm/pesq-doc-adm', [], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('zi3fqs79ieqmx1tcvf7te0h5l8tgwvz3', datetime.datetime(2016, 10, 11, 14, 16, 8, 167065, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/pesq-doc-adm -_____________ test_permissions_urls_for_users_by_apps[url_item30] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280268>, 'docadm/tramitacao-doc-adm/%(pk)s/tramitacaoadministrativo', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/tramitacao-doc-adm/1/tramitacaoadministrativo -_____________ test_permissions_urls_for_users_by_apps[url_item31] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc0502802f0>, 'docadm/tramitacao-doc-adm/%(pk)s/tramitacaoadministrativo/create', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/tramitacao-doc-adm/1/tramitacaoadministrativo/create -_____________ test_permissions_urls_for_users_by_apps[url_item32] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280378>, 'docadm/tramitacao-doc-adm/tramitacaoadministrativo/%(pk)s', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/tramitacao-doc-adm/tramitacaoadministrativo/1 -_____________ test_permissions_urls_for_users_by_apps[url_item33] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280488>, 'docadm/tramitacao-doc-adm/tramitacaoadministrativo/%(pk)s/delete', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/tramitacao-doc-adm/tramitacaoadministrativo/1/delete -_____________ test_permissions_urls_for_users_by_apps[url_item34] ______________ - -url_item = (._add_base..CrudViewWithBase at 0x7fc050280400>, 'docadm/tramitacao-doc-adm/tramitacaoadministrativo/%(pk)s/edit', ['pk'], 'sapl.protocoloadm') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:206: in render - return self._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:173: in render - return compiled_parent._render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/utils.py:92: in instrumented_test_render - return self.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/loader_tags.py:69: in render - result = block.nodelist.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:992: in render - bit = node.render_annotated(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:959: in render_annotated - return self.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:319: in render - match = condition.eval(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/defaulttags.py:951: in eval - return self.value.resolve(context, ignore_failures=True) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:736: in resolve - new_obj = func(obj, *arg_vals) -sapl/base/templatetags/common_tags.py:92: in get_doc_adm_template_perms - app_config = AppConfig.objects.last() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:559: in last - objects = list((self.reverse() if self.ordered else self.order_by('-pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_appconfig"."id", "base_appconfig"."documentos_administrativos", "base_appconfig"."sequencia_numeracao", ..._materia", "base_appconfig"."texto_articulado_norma" FROM "base_appconfig" ORDER BY "base_appconfig"."id" DESC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.ProgrammingError: column base_appconfig.texto_articulado_proposicao does not exist -E LINE 1: ...cia_numeracao", "base_appconfig"."painel_aberto", "base_appc... -E ^ - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: ProgrammingError ------------------------------ Captured stdout call ----------------------------- -operador_geral {'operador_geral': ['/sistema', '/docadm', '/protocoloadm'], 'operador_administrativo': ['/docadm'], 'operador_protocoloadm': ['/protocoloadm']} /docadm/tramitacao-doc-adm/tramitacaoadministrativo/1/edit -_____________ test_permissions_urls_for_users_by_apps[url_item35] ______________ - -url_item = (, 'login/', [], 'sapl.base') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('c1uywktes83r58cl8d3wl7q9t8slb8ic', datetime.datetime(2016, 10, 11, 14, 16, 19, 138164, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema']} /login/ -_____________ test_permissions_urls_for_users_by_apps[url_item36] ______________ - -url_item = (, 'logout/', [], 'sapl.base') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:505: in get - response = self._handle_redirects(response, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:686: in _handle_redirects - response = self.get(path, QueryDict(url.query), follow=False, **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:174: in get_response - response = self.process_exception_by_middleware(e, request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:172: in get_response - response = response.render() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:160: in render - self.content = self.rendered_content -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/response.py:137: in rendered_content - content = template.render(context, self._request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/backends/django.py:95: in render - return self.template.render(context) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/template/base.py:204: in render - with context.bind_template(self): -/usr/lib/python3.4/contextlib.py:59: in __enter__ - return next(self.gen) -../../.virtualenvs/sapl/lib/python3.4/site-packages/debug_toolbar/panels/templates/panel.py:49: in _request_context_bind_template - context = processor(self.request) -sapl/context_processors.py:7: in parliament_info - casa = get_casalegislativa() -sapl/base/views.py:26: in get_casalegislativa - return CasaLegislativa.objects.first() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:550: in first - objects = list((self if self.ordered else self.order_by('pk'))[:1]) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:258: in __iter__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "base_casalegislativa"."id", "base_casalegislativa"."codigo", "base_casalegislativa"."nome", "base_casalegisla..."base_casalegislativa"."informacao_geral" FROM "base_casalegislativa" ORDER BY "base_casalegislativa"."id" ASC LIMIT 1' -params = () - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_geral': ['/sistema']} /logout/ -_____________ test_permissions_urls_for_users_by_apps[url_item39] ______________ - -url_item = (, 'materia/%(pk)s/acompanhar-confirmar', ['pk'], 'sapl.materia') -client = - - @pytest.mark.parametrize('url_item', _lista_urls) - def test_permissions_urls_for_users_by_apps(url_item, client): - key, url, var, app_name = url_item - url = '/' + (url % {v: 1 for v in var}) - - if not get_user_model().objects.exists(): - for app in sapl_appconfs: - # readequa permissões dos models adicionando - # list e detail permissions - create_perms_post_migrate(app) - # cria usuários de perfil do sapl - cria_grupos_permissoes() - users = get_user_model().objects.values_list('username', flat=True) - - app_labels = app_name.split('.')[1] - - view = None - if hasattr(key, 'view_class'): - view = key.view_class() - - """ - A classe PermissionRequiredForAppCrudMixin pode ser usada em uma - app mas envolver permissoes para outras - como é o caso de PainelView que está na app 'sessao' - mas é um redirecionamento para 'painel'... aqui é feita - a troca da app a ser testada, por essas outras possíveis. - - Este, até a ultima versão deste teste é o único tipo de view que - possui restrição restrição simples, por permissão, e não por - container, como é o caso de proposições que possui restrição - por usuário e não só por, ou não tem, o campo permission_required - """ - if PermissionRequiredForAppCrudMixin in type.mro(key.view_class): - # essa classe deve informar app_label - assert hasattr(key.view_class, 'app_label') - # app_label deve ter conteudo - assert key.view_class.app_label - app_labels = key.view_class.app_label - else: - - if hasattr(view, 'permission_required') and \ - view.permission_required is not None and\ - len(view.permission_required) == 0: - """ - condição do Crud, se tem permission_required e ele é igual [], - então é uma view pública, teste liberado. - """ - return - else: - """ - Views que não se encaixam nãs condições acima, podem possuir - ou não restrição de acesso. Se o código continuar, - será tratado como tentativa de validar pois é possível - ter restrição local, como uma anotação method_required. - Caberá ao desenvolvedor de uma nova view, se for pública e - sem necessidade de nenhum tratamento de permissão, para limpar - o teste to py.test adicionar sua url - representativa na variavel externa ao teste: - - urls_publicas_excecoes, logo acima do teste - """ - pass - - if isinstance(app_labels, str): - app_labels = app_labels, - - for app in app_labels: - - assert app in apps_url_patterns_prefixs_and_users, """ - O app_label (%s) associado a url (%s) não está na base de testes. - %s - """ % (app_name, url) - - if 'users' not in apps_url_patterns_prefixs_and_users[app]: - continue - - users_for_url_atual_app = apps_url_patterns_prefixs_and_users[ - app]['users'] - - for username in users: - print(username, users_for_url_atual_app, url) - - client.login(username=username, password='interlegis') - - rg = None - try: - if url not in urls_publicas_excecoes['get']: - rg = client.get(url, {}, follow=True) - except: - pass - - rp = None - try: - if url not in urls_publicas_excecoes['post']: - rp = client.post(url, {}, follow=True) - except: - pass - - """ - devido às urls serem incompletas ou com pks e outras valores - inexistentes na base, iniciar a execução da view, seja por get, - post ou qualquer outro método pode causar o erro... - por isso o "try ... except" acima. - No entanto, o objetivo do teste é validar o acesso de toda url. - Independente do erro que vá acontecer, esse erro não ocorrerá - se o user não tiver permissão de acesso pelo fato de que "AS - VIEWS BEM FORMADAS PARA VALIDAÇÃO DE ACESSO DEVEM SEMPRE - REDIRECIONAR PARA - LOGIN ANTES DE SUA EXECUÇÃO", desta forma nunca gerando erro - interno dada qualquer incoerência de parâmetros nas urls - """ - - for _type, content in ( - ('get', str(rg.content if rg else '')), - ('post', str(rp.content if rp else ''))): - - if not content: - continue - - def _assert_login(_in): - if _in: - assert btn_login in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) deveria ser redirecionado - para tela de login. - """ % (_type, url, app, username) - else: - assert btn_login not in content, """ - No teste de requisição "%s" a url (%s). - App (%s) - O usuário (%s) não deveria ser redirecionado - para tela de login. Se essa é uma url - invariavelmente pública, a adicione na variavel - abaixo localizada no arquivo que se encontra este - teste: - - urls_publicas_excecoes - - - """ % (_type, url, app, username) - - if username not in users_for_url_atual_app: - # se não é usuário da app deve ser redirecionado para login - _assert_login(True) - else: - prefixs = users_for_url_atual_app[username] - for pr in prefixs: - if url.startswith(pr): - _assert_login(False) - break - -> client.get('/logout/', follow=True) - -sapl/test_urls.py:473: -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:503: in get - **extra) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:304: in get - return self.generic('GET', path, secure=secure, **r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:380: in generic - return self.request(**r) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/test/client.py:467: in request - six.reraise(*exc_info) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:686: in reraise - raise value -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/core/handlers/base.py:123: in get_response - response = middleware_method(request) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/middleware/locale.py:25: in process_request - request, check_path=self.is_language_prefix_patterns_used) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/__init__.py:199: in get_language_from_request - return _trans.get_language_from_request(request, check_path) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/translation/trans_real.py:494: in get_language_from_request - lang_code = request.session.get(LANGUAGE_SESSION_KEY) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:61: in get - return self._session.get(key, default) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/base.py:201: in _get_session - self._session_cache = self.load() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/contrib/sessions/backends/db.py:33: in load - expire_date__gt=timezone.now() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/manager.py:122: in manager_method - return getattr(self.get_queryset(), name)(*args, **kwargs) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:381: in get - num = len(clone) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:240: in __len__ - self._fetch_all() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:1074: in _fetch_all - self._result_cache = list(self.iterator()) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/query.py:52: in __iter__ - results = compiler.execute_sql() -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/models/sql/compiler.py:848: in execute_sql - cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: in execute - return self.cursor.execute(sql, params) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/utils.py:95: in __exit__ - six.reraise(dj_exc_type, dj_exc_value, traceback) -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/utils/six.py:685: in reraise - raise value.with_traceback(tb) -_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ - -self = -sql = 'SELECT "django_session"."session_key", "django_session"."session_data", "django_session"."expire_date" FROM "django_session" WHERE ("django_session"."session_key" = %s AND "django_session"."expire_date" > %s)' -params = ('uvoajg1ljw8wo30glsjnaridxyjxvv92', datetime.datetime(2016, 10, 11, 14, 16, 24, 515850, tzinfo=)) - - def execute(self, sql, params=None): - self.db.validate_no_broken_transaction() - with self.db.wrap_database_errors: - if params is None: - return self.cursor.execute(sql) - else: -> return self.cursor.execute(sql, params) -E django.db.utils.InternalError: current transaction is aborted, commands ignored until end of transaction block - -../../.virtualenvs/sapl/lib/python3.4/site-packages/django/db/backends/utils.py:64: InternalError ------------------------------ Captured stdout call ----------------------------- -operador_administrativo {'operador_autor': ['/proposicao'], 'operador_geral': ['/sistema', '/materia'], 'operador_materia': ['/materia']} /materia/1/acompanhar-confirmar -!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! KeyboardInterrupt !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -to show a full traceback on KeyboardInterrupt use --fulltrace -/usr/lib/python3.4/ast.py:172: KeyboardInterrupt -========= 100 failed, 1449 passed, 1 pytest-warnings in 159.31 seconds ========= From cb23daf808a53ff3c3ec9874a7ebc848b4c04fa1 Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Thu, 20 Oct 2016 18:01:24 -0200 Subject: [PATCH 09/16] =?UTF-8?q?Esconde=20formul=C3=A1rio=20caso=20n?= =?UTF-8?q?=C3=A3o=20encontre=20mat=C3=A9rias=20em=20tramita=C3=A7=C3=A3o?= =?UTF-8?q?=20e=20acess=C3=B3rio=20em=20lote?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/templates/materia/em_lote/acessorio.html | 138 +++++++------- .../templates/materia/em_lote/tramitacao.html | 168 +++++++++--------- 2 files changed, 153 insertions(+), 153 deletions(-) diff --git a/sapl/templates/materia/em_lote/acessorio.html b/sapl/templates/materia/em_lote/acessorio.html index 6fae58731..5035d8956 100644 --- a/sapl/templates/materia/em_lote/acessorio.html +++ b/sapl/templates/materia/em_lote/acessorio.html @@ -14,87 +14,87 @@ {% else %}

{% blocktrans with object_list.count as total_materias %}Foram encontradas {{total_materias}} matérias.{% endblocktrans %}

{% endif %} - {% else %} -

Nenhuma matéria encontrada.

- {% endif %} -
- {% csrf_token %} -
- Documento Acessório -
-
- - -
+ + {% csrf_token %} +
+ Documento Acessório +
+
+ + +
-
- - -
+
+ + +
-
- - +
+ + +
-
-
-
- - -
+
+
+ + +
- + -
-
-
-
+
+
+
+
+
-
-
-
- - +
+
+ + +
-
-
-
- - +
+
+ + +
-
-
+
-


+


-
- Matérias para inclusão do Documento Acessório - - - - - - {% for materia in object_list %} - - - - {% endfor %} - -
Matéria
- - {{materia.tipo.sigla}} {{materia.numero}}/{{materia.ano}} - {{materia.tipo.descricao}} -
-
- -
+
+ Matérias para inclusão do Documento Acessório + + + + + + {% for materia in object_list %} + + + + {% endfor %} + +
Matéria
+ + {{materia.tipo.sigla}} {{materia.numero}}/{{materia.ano}} - {{materia.tipo.descricao}} +
+
+ + + {% else %} +

Nenhuma matéria encontrada.

+ {% endif %} {% endif %} {% endblock detail_content %} diff --git a/sapl/templates/materia/em_lote/tramitacao.html b/sapl/templates/materia/em_lote/tramitacao.html index b9845f55b..687dcddd2 100644 --- a/sapl/templates/materia/em_lote/tramitacao.html +++ b/sapl/templates/materia/em_lote/tramitacao.html @@ -14,104 +14,104 @@ {% else %}

Foram encontradas {{object_list|length}} matérias.

{% endif %} - {% else %} -

Nenhuma matéria encontrada.

- {% endif %} -
- {% csrf_token %} -
- 1. Detalhes da tramitação: + + {% csrf_token %} +
+ 1. Detalhes da tramitação: -
-
- - -
+
+
+ + +
-
- - -
+
+ + +
-
- - +
+ + +
-
-
-
- - {% if unidade_local|length > 1 %}{% endif %} - -
+
+
+ + {% if unidade_local|length > 1 %}{% endif %} + +
-
- - +
+ + +
-
-
-
- - -
+
+
+ + +
-
- - -
+
+ + +
-
- - +
+ + +
-
-
-
- - +
+
+ + +
-
-
+
-


+


-
- 2. Selecione as matérias para primeira tramitação: - - - - - - {% for materia in object_list %} - - - - {% endfor %} - -
Matéria
- - {{materia.tipo.sigla}} {{materia.tipo.descricao}} {{materia.numero}}/{{materia.ano}} -
-
- -
+
+ 2. Selecione as matérias para primeira tramitação: + + + + + + {% for materia in object_list %} + + + + {% endfor %} + +
Matéria
+ + {{materia.tipo.sigla}} {{materia.tipo.descricao}} {{materia.numero}}/{{materia.ano}} +
+
+ + + {% else %} +

Nenhuma matéria encontrada.

+ {% endif %} {% endif %} {% endblock detail_content %} From 5a29fe721b0cc617fae4355a52efa911d986afb4 Mon Sep 17 00:00:00 2001 From: Eduardo Calil Date: Thu, 20 Oct 2016 18:16:14 -0200 Subject: [PATCH 10/16] Troca a imagem do pdf em pauta de sessao --- sapl/static/img/pdflogo.png | Bin 0 -> 243876 bytes sapl/templates/sessao/pauta_sessao_filter.html | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) create mode 100644 sapl/static/img/pdflogo.png diff --git a/sapl/static/img/pdflogo.png b/sapl/static/img/pdflogo.png new file mode 100644 index 0000000000000000000000000000000000000000..ae28bf4285dd2c39dc1092c21fb3624886ba6f6d GIT binary patch literal 243876 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�z$!Pn2 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

cDUT|v2h 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

Ky?5_4 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 mQ2(cP`K0%D%KUNr{ttt?uzFwC+a {{s}}
- + {% endfor %} From 454a473de676e1dd53bcacc2359010e3232666db Mon Sep 17 00:00:00 2001 From: Edward Ribeiro Date: Thu, 20 Oct 2016 18:16:51 -0200 Subject: [PATCH 11/16] Adiciona codeclimate --- .codeclimate.yml | 11 +++++++++++ README.rst | 2 ++ 2 files changed, 13 insertions(+) create mode 100644 .codeclimate.yml diff --git a/.codeclimate.yml b/.codeclimate.yml new file mode 100644 index 000000000..430012579 --- /dev/null +++ b/.codeclimate.yml @@ -0,0 +1,11 @@ +engines: + duplication: + enabled: true + config: + languages: + - python + - javascript +exclude_paths: +- sapl/**/migrations/* +- sapl/**/legacy/* +- sapl/relatorios/ diff --git a/README.rst b/README.rst index 6a7a74b91..a3c671293 100644 --- a/README.rst +++ b/README.rst @@ -1,6 +1,8 @@ .. image:: https://travis-ci.org/interlegis/sapl.svg?branch=master :target: https://travis-ci.org/interlegis/sapl +[![Code Climate](https://codeclimate.com/github/interlegis/sapl/badges/gpa.svg)](https://codeclimate.com/github/interlegis/sapl) + *********************************************** SAPL - Sistema de Apoio ao Processo Legislativo *********************************************** From 7f3f705c7cd38e506667c330077abc601ea538a1 Mon Sep 17 00:00:00 2001 From: Edward Ribeiro Date: Thu, 20 Oct 2016 18:18:42 -0200 Subject: [PATCH 12/16] Retira badge do codeclimate --- README.rst | 1 - 1 file changed, 1 deletion(-) diff --git a/README.rst b/README.rst index a3c671293..a40fae4f5 100644 --- a/README.rst +++ b/README.rst @@ -1,7 +1,6 @@ .. image:: https://travis-ci.org/interlegis/sapl.svg?branch=master :target: https://travis-ci.org/interlegis/sapl -[![Code Climate](https://codeclimate.com/github/interlegis/sapl/badges/gpa.svg)](https://codeclimate.com/github/interlegis/sapl) *********************************************** SAPL - Sistema de Apoio ao Processo Legislativo From 3b2cb97d9db8fa66d5bf1eafe3a42bd463c55f3a Mon Sep 17 00:00:00 2001 From: Edward Ribeiro Date: Thu, 20 Oct 2016 18:24:12 -0200 Subject: [PATCH 13/16] Remove yaml file do codeclimate --- .codeclimate.yml | 11 ----------- 1 file changed, 11 deletions(-) delete mode 100644 .codeclimate.yml diff --git a/.codeclimate.yml b/.codeclimate.yml deleted file mode 100644 index 430012579..000000000 --- a/.codeclimate.yml +++ /dev/null @@ -1,11 +0,0 @@ -engines: - duplication: - enabled: true - config: - languages: - - python - - javascript -exclude_paths: -- sapl/**/migrations/* -- sapl/**/legacy/* -- sapl/relatorios/ From 08e8375fe7794671196d7eb52e4fea56e680259b Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Fri, 21 Oct 2016 11:03:48 -0200 Subject: [PATCH 14/16] =?UTF-8?q?Torna=20unidade=20destino=20de=20'Tramita?= =?UTF-8?q?caoAdministrativo'=20obrigat=C3=B3rio?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/protocoloadm/models.py | 2 -- 1 file changed, 2 deletions(-) diff --git a/sapl/protocoloadm/models.py b/sapl/protocoloadm/models.py index 4ec3393ed..667a065a9 100644 --- a/sapl/protocoloadm/models.py +++ b/sapl/protocoloadm/models.py @@ -168,8 +168,6 @@ class TramitacaoAdministrativo(models.Model): blank=True, null=True, verbose_name=_('Data Encaminhamento')) unidade_tramitacao_destino = models.ForeignKey( UnidadeTramitacao, - blank=True, - null=True, related_name='adm_tramitacoes_destino', verbose_name=_('Unidade Destino')) texto = models.TextField( From 243ccb2d08ca7b4c102137c8ba9468cf756ff0a8 Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Fri, 21 Oct 2016 11:10:46 -0200 Subject: [PATCH 15/16] =?UTF-8?q?Fix=20field=20em=20tramita=C3=A7=C3=A3o?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/materia/views.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sapl/materia/views.py b/sapl/materia/views.py index a85bdeb5f..9d5d101ec 100644 --- a/sapl/materia/views.py +++ b/sapl/materia/views.py @@ -540,7 +540,7 @@ class TramitacaoCrud(MasterDetailCrud): class BaseMixin(MasterDetailCrud.BaseMixin): list_field_names = ['data_tramitacao', 'unidade_tramitacao_local', - 'mitacao_destino', 'status'] + 'unidade_tramitacao_destino', 'status'] ordered_list = False ordering = '-data_tramitacao', From 94858162814f553bc5a08429cc4f8bd4da4a1364 Mon Sep 17 00:00:00 2001 From: Eduardo Edson Batista Cordeiro Alves Date: Fri, 21 Oct 2016 11:24:16 -0200 Subject: [PATCH 16/16] =?UTF-8?q?Torna=20o=20campo=20de=20comiss=C3=A3o=20?= =?UTF-8?q?n=C3=A3o=20editavel=20em=20relatoria?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/templates/materia/relatoria_form.html | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/sapl/templates/materia/relatoria_form.html b/sapl/templates/materia/relatoria_form.html index 953557513..f8fbdaf5e 100644 --- a/sapl/templates/materia/relatoria_form.html +++ b/sapl/templates/materia/relatoria_form.html @@ -12,3 +12,9 @@ {% crispy form %} {% endif %} {% endblock %} + +{% block extra_js %} + +{% endblock extra_js %}