What is actually assertEquals in Python?
Asked Answered
L

6

19

I have the following test.py file in django. can you please explain this code?

from contacts.models import Contact
...
class ContactTests(TestCase):
    """Contact model tests."""

    def test_str(self):

        contact = Contact(first_name='John', last_name='Smith')

        self.assertEquals(
            str(contact),
            'John Smith',
        )
Licensee answered 29/7, 2013 at 9:38 Comment(5)
It will check if str(contact) == 'John Smith', if not then assert equal is failedGader
Did you ask the person who wrote it?Neslund
can you please define what actually assertEquals is?Licensee
Why don't you look in the documentation for the unittest module?Rianna
Just FYI that assertEquals is deprecated -- assertEqual is now the correct method name -- docs.python.org/2/library/unittest.html#deprecated-aliasesOse
G
33
from contacts.models import Contact  # import model Contact
...
class ContactTests(TestCase):  # start a test case
    """Contact model tests."""

    def test_str(self):  # start one test

        contact = Contact(first_name='John', last_name='Smith')  # create a Contact object with 2 params like that

        self.assertEquals(  # check if str(contact) == 'John Smith'
            str(contact),  
            'John Smith',
        )

Basically it will check if str(contact) == 'John Smith', if not then assert equal is failed and the test is failed and it will notify you the error at that line.

In other words, assertEquals is a function to check if two variables are equal, for purposes of automated testing:

def assertEquals(var1, var2):
    if var1 == var2:
        return True
    else:
        return False

Hope it helps.

Gader answered 29/7, 2013 at 9:42 Comment(1)
This is true, though you could rewrite any if statement like that (immediately returning either True or False more succinctly by doing return var1 == var2.Willodeanwilloughby
S
22

assertEquals is a (deprecated) alias for TestCase.assertEqual, which is a method on the unittest.TestCase class.

It forms a test assertion; where str(contact) must be equal to 'John Smith' for the test to pass.

The form with s has been marked as deprecated since 2010, but they've not actually been removed, and there is no concrete commitment to remove them at this point. If you run your tests with deprecation warnings enabled (as recommended in PEP 565) you'd see a warning:

test.py:42: DeprecationWarning: Please use assertEqual instead.
  self.assertEquals(
Swanger answered 29/7, 2013 at 9:41 Comment(4)
you linked to assertEqual not assertEqualsSorilda
@Boris: indeed, and I probably didn't even realise that at the time. I've updated this with a note on the fact that it is an alias for assertEqual and the fact that it is officially deprecated.Swanger
Is there any convention for the argument order? assertEqual("expected", calculated) or assertEqual(calculated, "expected")?Torpedoman
@EricDuminil: not that I am aware of. I personally always use calculated, "expected", but that's not set in stone. Free you must feel, Yoda assertions you can use!Swanger
S
2

assertEquals is deprecated since Python 3.2, you should use assertEqual (no s).

Or pytest.

Sorilda answered 11/11, 2019 at 3:35 Comment(0)
C
0

The assertEquals set your test as passed if the __str__ of your contact object returns 'John Smith`. This is part of unit tests, you should check the official documentation

Collate answered 29/7, 2013 at 9:40 Comment(0)
P
0

Syntax: assertEqual(first, second, msg=None)

Test that first and second are equal. If the values do not compare equal, the test will fail.In addition it will also check if first and second are the exact same type and one of list, tuple, dict, set, frozenset or unicode.

in your case it will check will check if str(contact) == 'John Smith', if not then assert equal is failed.

Pasahow answered 22/1, 2016 at 11:28 Comment(0)
F
0

assertEquals tests whether two variables are equal to each other.

Friel answered 10/10, 2017 at 5:52 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.