Skip to content

Commit

Permalink
Merge pull request #66 from souliane/master
Browse files Browse the repository at this point in the history
fix issue #65
  • Loading branch information
craigds authored Mar 14, 2023
2 parents 9724528 + ad3b474 commit c3346af
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 3 deletions.
2 changes: 1 addition & 1 deletion typedmodels/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -395,7 +395,7 @@ def __init__(self, *args, _typedmodels_do_recast=None, **kwargs):
self.recast()

def recast(self, typ=None):
for base in self.__class__.mro():
for base in reversed(self.__class__.mro()):
if issubclass(base, TypedModel) and hasattr(base, "_typedmodels_registry"):
break
else:
Expand Down
18 changes: 16 additions & 2 deletions typedmodels/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -195,20 +195,34 @@ def test_recast_auto(animals):
assert type(cat) == BigCat


def test_recast_string(animals):
def test_recast_to_subclass_string(animals):
cat = Feline.objects.get(name="kitteh")
cat.recast("testapp.bigcat")
assert cat.type == "testapp.bigcat"
assert type(cat) == BigCat


def test_recast_modelclass(animals):
def test_recast_to_subclass_modelclass(animals):
cat = Feline.objects.get(name="kitteh")
cat.recast(BigCat)
assert cat.type == "testapp.bigcat"
assert type(cat) == BigCat


def test_recast_string(animals):
cat = Feline.objects.get(name="kitteh")
cat.recast("testapp.canine")
assert cat.type == "testapp.canine"
assert type(cat) == Canine


def test_recast_modelclass(animals):
cat = Feline.objects.get(name="kitteh")
cat.recast(Canine)
assert cat.type == "testapp.canine"
assert type(cat) == Canine


def test_recast_fail(animals):
cat = Feline.objects.get(name="kitteh")
with pytest.raises(ValueError):
Expand Down

0 comments on commit c3346af

Please sign in to comment.