开发者

copy.copy(object) returns an object with id == None during tests?

开发者 https://www.devze.com 2023-02-10 18:34 出处:网络
I am new to Django and Python, building my first app using TDD...I wanted to copy an instance of Task, a model object.I used the following code, which works correctly during the tests:

I am new to Django and Python, building my first app using TDD... I wanted to copy an instance of Task, a model object. I used the following code, which works correctly during the tests:

import copy

class Task(models.Model): 
    ...
    def make_copy(self):
       new_task = copy.copy(self)
       new_task.save()
       return new_task

But when running this code 'normally开发者_如何转开发', in the server, I noticed it was not working: no new object was created. I found out I had to add new_task.id = None just before saving, and I understand the reason for this...

But if copy.copy does not know about Django and thus will not change the id itself, why is it the case that the object returned has id == None during the tests?


It sounds like your test case is not fully matching the usage in your "normal" use case.

The id field is set for objects that exist in the database. If you pass your make_copy() method an object with id set, it will appear to fail because it's not making a new database object, it's just saving an existing object (through the Python copy, with an existing id).

I'd guess your test case is passing Task objects to make_copy() with id of None (and therefore appearing to work), while in "normal" usage, the objects are coming in with id set. (You could test this hypothesis with a simple print or assert statement).

One simple solution might be to set id to None right after your copy operation. That way, a new database object is always created.

Finally, someone else with the same situation: http://www.nerdydork.com/copy-model-object-in-django.html

0

精彩评论

暂无评论...
验证码 换一张
取 消