Дополнительное предложение.
Вы можете использовать тесты носа и pdb вместе, вместо этого вручную добавляя pdb.set_trace()
в ваши представления. Преимущество состоит в том, что вы можете наблюдать ошибки при их первом запуске, возможно, в стороннем коде.
Вот ошибка для меня сегодня.
TypeError at /db/hcm91dmo/catalog/records/
render_option() argument after * must be a sequence, not int
....
Error during template rendering
In template /opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/crispy_forms/templates/bootstrap3/field.html, error at line 28
render_option() argument after * must be a sequence, not int
18
19 {% if field|is_checkboxselectmultiple %}
20 {% include 'bootstrap3/layout/checkboxselectmultiple.html' %}
21 {% endif %}
22
23 {% if field|is_radioselect %}
24 {% include 'bootstrap3/layout/radioselect.html' %}
25 {% endif %}
26
27 {% if not field|is_checkboxselectmultiple and not field|is_radioselect %}
28
{% if field|is_checkbox and form_show_labels %}
Теперь, я знаю, это означает, что я обманываю конструктор для формы, и у меня даже есть хорошее представление о том, какое поле является проблемой. Но могу ли я использовать pdb, чтобы увидеть, на что жалуются хрустящие формы, в шаблоне ?
Да, я могу. Используя опцию - pdb при тестировании носа:
tests$ nosetests test_urls_catalog.py --pdb
Как только я нажимаю на любое исключение (в том числе обработанное изящно), pdb останавливается там, где это происходит, и Я могу осмотреться.
File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/django/forms/forms.py", line 537, in __str__
return self.as_widget()
File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/django/forms/forms.py", line 593, in as_widget
return force_text(widget.render(name, self.value(), attrs=attrs))
File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/django/forms/widgets.py", line 513, in render
options = self.render_options(choices, [value])
File "/opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/django/forms/widgets.py", line 543, in render_options
output.append(self.render_option(selected_choices, *option))
TypeError: render_option() argument after * must be a sequence, not int
INFO lib.capture_middleware log write_to_index(http://localhost:8082/db/hcm91dmo/catalog/records.html)
INFO lib.capture_middleware log write_to_index:end
> /opt/local/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/django/forms/widgets.py(543)render_options()
-> output.append(self.render_option(selected_choices, *option))
(Pdb) import pprint
(Pdb) pprint.PrettyPrinter(indent=4).pprint(self)
<django.forms.widgets.Select object at 0x115fe7d10>
(Pdb) pprint.PrettyPrinter(indent=4).pprint(vars(self))
{ 'attrs': { 'class': 'select form-control'},
'choices': [[('_', 'any type'), (7, (7, 'type 7', 'RECTYPE_TABLE'))]],
'is_required': False}
(Pdb)
Теперь ясно, что мой аргумент выбора для хрустящего конструктора поля был как список внутри списка, а не как список / кортеж кортежей.
'choices': [[('_', 'any type'), (7, (7, 'type 7', 'RECTYPE_TABLE'))]]
Замечательно то, что этот pdb находится в коде crispy, а не в моем, и мне не нужно было вставлять его вручную.
Varargs обрабатываются компилятором как Object [], что и описывается в сообщении об ошибке.
У меня нет опыта работы с JRuby, но работает ли он, если у вас есть аргумент массива?
Похоже, это известная ошибка в jruby. См. диспетчеризация метода для объектов / классов Java должна попытаться найти соответствующий метод varargs и NameError, выдаваемый при попытке передать аргумент в метод Java, который определен как имеющий аргументы переменной длины .
Согласно ссылке, Rhino поддерживает vararg .
Java внутренне обрабатывает список аргументов переменной длины как массив, элементы которого все одного типа. По этой причине вам необходимо предоставить массив объектов в вашем сценарии JRuby.
Он работает следующим образом:
myMethod [42, 2009].to_java
Метод to_java
создает массив Java из массива Ruby. По умолчанию to_java
создает массивы объектов по мере необходимости в этом случае. Если вам нужен массив String, вы можете использовать
["a","b","c"].to_java(:string)
Подробнее об этом на JRuby wiki