- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Attachment
模型,该模型在 Django 1.4.1 应用程序中具有 FileField
。此 FileField
有一个可调用的 upload_to
参数,根据 Django docs应该在保存表单(以及模型)时调用。
当我运行下面的 FormTest
时,永远不会调用 upload_to
可调用函数,因此该文件不会出现在 upload_to< 提供的位置中
方法。我做错了什么?
请注意,在 ModelTest
(也在下面)中通过测试时,upload_to
方法按预期工作。
我看过的事情不是似乎是问题所在:
Attachment
模型中属性的顺序。我发现一些问题似乎表明这个顺序很重要。由于我的 upload_to
方法使用 directory
属性,我认为他的方法可能会导致问题。它不是。无论如何,这不会导致该方法不被调用。is_valid()
没有被调用。不,我已经确认是这样。测试:
from core.forms.attachments import AttachmentForm
from django.test import TestCase
import unittest
from django.core.files.uploadedfile import SimpleUploadedFile
from django.core.files.storage import default_storage
def suite():
return unittest.TestSuite(
[
unittest.TestLoader().loadTestsFromTestCase(FormTest),
]
)
class FormTest(TestCase):
def test_form_1(self):
filename = 'filename'
f = file(filename)
data = {'name':'name',}
file_data = {'attachment_file':SimpleUploadedFile(f.name,f.read()),}
form = AttachmentForm(data=data,files=file_data)
self.assertTrue(form.is_valid())
attachment = form.save()
root_directory = 'attachments'
upload_location = root_directory + '/' + attachment.directory + '/' + filename
self.assertTrue(attachment.attachment_file) # Fails
self.assertTrue(default_storage.exists(upload_location)) # Fails
附件模型:
from django.db import models
from parent_mixins import Parent_Mixin
import uuid
from django.db.models.signals import pre_delete,pre_save
from dirtyfields import DirtyFieldsMixin
def upload_to(instance,filename):
return 'attachments/' + instance.directory + '/' + filename
def uuid_directory_name():
return uuid.uuid4().hex
class Attachment(DirtyFieldsMixin,Parent_Mixin,models.Model):
attachment_file = models.FileField(blank=True,null=True,upload_to=upload_to)
directory = models.CharField(blank=False,default=uuid_directory_name,null=False,max_length=32)
name = models.CharField(blank=False,default=None,null=False,max_length=128)
class Meta:
app_label = 'core'
def __str__(self):
return unicode(self).encode('utf-8')
def __unicode__(self):
return unicode(self.name)
@models.permalink
def get_absolute_url(self):
return('core_attachments_update',(),{'pk': self.pk})
# def save(self,*args,**kwargs):
# super(Attachment,self).save(*args,**kwargs)
def pre_delete_callback(sender, instance, *args, **kwargs):
if not isinstance(instance, Attachment): return
if not instance.attachment_file: return
instance.attachment_file.delete(save=False)
def pre_save_callback(sender, instance, *args, **kwargs):
if not isinstance(instance, Attachment): return
if not instance.attachment_file: return
if instance.is_dirty():
dirty_fields = instance.get_dirty_fields()
if 'attachment_file' in dirty_fields:
old_attachment_file = dirty_fields['attachment_file']
old_attachment_file.delete()
pre_delete.connect(pre_delete_callback)
pre_save.connect(pre_save_callback)
附件表格:
from ..models.attachments import Attachment
from crispy_forms.helper import FormHelper
from crispy_forms.layout import Div,Layout,HTML,Field,Fieldset,Button,ButtonHolder,Submit
from django import forms
class AttachmentFormHelper(FormHelper):
form_tag=False
layout = Layout(
Div(
Div(
Field('name',css_class='span4'),
Field('attachment_file',css_class='span4'),
css_class='span4',
),
css_class='row',
),
)
class AttachmentForm(forms.ModelForm):
helper = AttachmentFormHelper()
class Meta:
fields=('attachment_file','name')
model = Attachment
class AttachmentInlineFormHelper(FormHelper):
form_tag=False
form_style='inline'
layout = Layout(
Div(
Div(
Field('name',css_class='span4'),
Field('attachment_file',css_class='span4'),
Field('DELETE',css_class='span4'),
css_class='span4',
),
css_class='row',
),
)
class AttachmentInlineForm(forms.ModelForm):
helper = AttachmentInlineFormHelper()
class Meta:
fields=('attachment_file','name')
model = Attachment
更新
我还使用这些单元测试对 Attachment
模型类进行测试 - 全部通过:
from core.models.attachments import Attachment
from core.models.attachments import upload_to
from django.test import TestCase
import unittest
from django.core.files.storage import default_storage
from django.core.files.base import ContentFile
def suite():
return unittest.TestSuite(
[
unittest.TestLoader().loadTestsFromTestCase(ModelTest),
]
)
class ModelTest(TestCase):
def test_model_minimum_fields(self):
attachment = Attachment(name='name')
attachment.attachment_file.save('test.txt',ContentFile("hello world"))
attachment.save()
self.assertEqual(str(attachment),'name')
self.assertEqual(unicode(attachment),'name')
self.assertTrue(attachment.directory)
# def test_model_full_fields(self):
# attachment = Attachment()
# attachement.save()
def test_file_operations_basic(self):
root_directory = 'attachments'
filename = 'test.txt'
attachment = Attachment(name='name')
attachment.attachment_file.save(filename,ContentFile('test'))
attachment.save()
upload_location = root_directory + '/' + attachment.directory + '/' + filename
self.assertEqual(upload_to(attachment,filename),upload_location)
self.assertTrue(default_storage.exists(upload_location))
def test_file_operations_delete(self):
root_directory = 'attachments'
filename = 'test.txt'
attachment = Attachment(name='name')
attachment.attachment_file.save(filename,ContentFile('test'))
attachment.save()
upload_location = upload_to(attachment,filename)
attachment.delete()
self.assertFalse(default_storage.exists(upload_location))
def test_file_operations_change(self):
root_directory = 'attachments'
filename_1 = 'test_1.txt'
attachment = Attachment(name='name')
attachment.attachment_file.save(filename_1,ContentFile('test'))
attachment.save()
upload_location_1 = upload_to(attachment,filename_1)
self.assertTrue(default_storage.exists(upload_location_1))
filename_2 = 'test_2.txt'
attachment.attachment_file.save(filename_2,ContentFile('test'))
attachment.save()
upload_location_2 = upload_to(attachment,filename_2)
self.assertTrue(default_storage.exists(upload_location_2))
self.assertFalse(default_storage.exists(upload_location_1))
最佳答案
如果我将 Attachment
模型的 attachment_file
字段更改为不允许空白或空值,则测试可以通过。
具体改变
attachment_file = models.FileField(blank=True,null=True,upload_to=upload_to)
至
attachment_file = models.FileField(blank=False,null=False,upload_to=upload_to)
我不知道为什么这会对我的测试产生影响,并且希望得到 Django 专家的解释。如果这些参数不为 False,为什么 FileField 不会保存文件?
关于Django FileField 未保存到 upload_to 位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13040580/
我正在尝试为FileField模型创建动态上载路径。因此,当用户上传文件时,Django将其存储到我的计算机/media/(用户名)/(path_to_a_file)/(文件名)中。 例如。/medi
我知道您可以使用 upload_to 参数传递一个可调用函数来动态更改 Django 模型中的 FileFied/ImageField 等。 由upload_to 调用的函数传递了2 个变量,即未保存
我编写了一个简单的 django 应用程序来测试 ImageField,但我遇到了问题,upload_to 似乎不起作用。下面是代码: 1 from django.db import models
当我的用户创建个人资料时,他们的图像保存得很好,但当他们更新它时,图像不会保存。我也不知道如何提取图片以便他们在更新之前可以看到它。 这是表格: class UpdateProfileForm(for
假设我们有两个模型:A 和 B。模型 A 有一个 upload_to 路径,在其中,我还想在同一路径上保存模型 B 中的字段。这就是我想做的: def random_path(instance, fi
我看过很多关于这个问题的帖子,但并没有真正理解如何解决它。 我有这个模型: class Project(TimeStampedModel): name = models.TextField(m
鉴于以下模型,我尝试在 upload_to 路径中使用模型 ID 字段(一个 UUID),但它被定义为 None,大概是因为它当时还没有生成。 如果我使用未定义为主键的 UUID 字段,它可以正常工作
我正在使用带有FileField的模型来处理文件上传。现在,文件可以成功上传了。但是,我还想做一个小的改进,那就是使用用户名为用户创建文件夹。 这是我尝试过的代码 class UserFiles(mo
我有一个 Attachment 模型,该模型在 Django 1.4.1 应用程序中具有 FileField 。此 FileField 有一个可调用的 upload_to 参数,根据 Django d
假设我有很多这样的模型: class ExampleModel(models.Model): photo = models.ImageField(upload_to='photos/')
我正在为带有 FileField 的 Django 模型编写测试用例。我想更改上传路径以防止测试对系统的其余部分产生副作用。 我已经尝试将可调用传递给 upload_to 并在测试中对其进行修补: #
我有这样一个模型: class MyModel(models.Model): red = models.ForeignKey(Anothermodel) blue = models.I
我在理解和使用 Django 的 ImageField 时遇到问题。 我有一个模型: class BlogContent(models.Model): title = models.CharF
我正在尝试设置我的上传,以便如果用户 joe 上传一个文件,它会转到 MEDIA_ROOT/joe,而不是让每个人的文件都转到 MEDIA_ROOT。问题是我不知道如何在模型中定义它。以下是它目前的样
我正在尝试替换将在我的模型中为某个 ImageField 上传的图像。现在我的模型是这样的: class Image(models.Model): image = models.ImageFi
我的类(class)有 Django ImageField我一直在努力在两种存储该字段的替代方案之间做出决定 upload_to功能。第一种方法非常简单。该函数在模块级别定义(参见 https://s
我正在创建一个图像模型,其他模型将通过通用关系使用它。例如,Newsposts 和 events 将有图像。下面是示例图像模型 class Image(models.Model): descri
为什么 upload_to 的值改变了 photo.name 的值?我试图在运行时创建一个相册目录,并在适当的相册目录中讲述我的图像。我的代码能够创建一个具有适当相册名称的目录并在其中包含正确的照片,
我的部署脚本覆盖了媒体和源目录,这意味着我必须将上传目录移出媒体目录,并在提取上传文件后替换它。 如何指示 django 上传到/uploads/而不是/media/? 到目前为止,我不断收到 dja
我有一个允许我上传文件的模型,但由于某种原因,自定义 upload_to 函数中定义的空格在文件系统(或 s3)中被下划线替换文件名和文件夹路径。 有没有办法强制使用空格? 例如:文件“hello w
我是一名优秀的程序员,十分优秀!