2017-02-11 60 views
0

我正在使用django-simple-captcha,它在本地工作正常。它是在页面给出了一个500错误一旦部署到Heroku的(唯一的日志输出我得到的是(2017-02-11T13:26:07.367450+00:00 heroku[router]: at=info method=GET path="/contact/" host=fathomless-harbor-1234.herokuapp.com request_id=37555c3c-c468-40cb-a142-c7dd04519e2c fwd="73.163.191.194" dyno=web.1 connect=1ms service=83ms status=500 bytes=386)。django-simple-captcha破解heroku部署

我跑了,并有三个失败的测试,所有这些有File "/Users/pmn/.virtualenvs/within/lib/python2.7/site-packages/django/template/loader.py", line 43, in get_template raise TemplateDoesNotExist(template_name, chain=chain) TemplateDoesNotExist: captcha_test/image.html

类似的错误

我在Django的1.9.6和Django的简单验证码0.5.3

forms.py

from django import forms 
from django.template.loader import get_template 
from django.core.mail import EmailMultiAlternatives 

from captcha.fields import CaptchaField 


class ContactForm(forms.Form): 

    contact_name = forms.CharField() 
    contact_email = forms.EmailField() 
    contact_phone = forms.CharField() 
    content = forms.CharField(widget=forms.Textarea) 
    cc_me = forms.BooleanField(required=False, initial=False) 
    captcha = CaptchaField(required=True) 

    def send_email(self): 
     contact_name = self.data["contact_name"] 
     contact_phone = self.data["contact_phone"] 
     contact_email = self.data["contact_email"] 
     content = self.data["content"] 

     template = get_template("contact.txt") 

     context = { 
      "contact_name": contact_name, 
      "contact_phone": contact_phone, 
      "contact_email": contact_email, 
      "content": content, 
     } 

     content = template.render(context) 
     subject, from_email, to = "Inquiry", contact_email, "[email protected]" 
     cc_address = contact_email if "cc_me" in self.data else None 
     email = EmailMultiAlternatives(
      subject, 
      content, 
      from_email, 
      ["[email protected]"], 
      cc=[cc_address], 
      headers={"Reply-To": contact_email} 
     ) 
     email.send() 

    def __init__(self, *args, **kwargs): 
     super(ContactForm, self).__init__(*args, **kwargs) 
     for field in self.fields: 
      self.fields[field].widget.attrs['class'] = 'form-control' 

(请注意,如果我注释掉两个验证码线,在部署页面加载)

+0

注意,如果有更详细的日志可用,请将它们指出来,我将不胜感激。 – thumbtackthief

+0

你有没有对'settings.py'本地进行任何未提交的更改?或者你在Heroku上使用不同的设置?这听起来像应用程序可能不在你的'INSTALLED_APPS'中。 – Chris

+0

不,它绝对在'INSTALLED_APPS'中。我应该澄清,虽然它在本地工作,但在本地运行测试套件会导致三次失败的测试,所有测试都会出现上述错误。虽然本地似乎没有影响任何东西。 – thumbtackthief

回答

0

问题是数据库迁移尚未在Heroku上运行。 heroku run python manage.py makemigrationsheroku run python manage.py migrate固定它。