Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

comparingOnlyFields gives false positive on Iterable objects #3129

Closed
mikehaertl opened this issue Jul 31, 2023 · 5 comments
Closed

comparingOnlyFields gives false positive on Iterable objects #3129

mikehaertl opened this issue Jul 31, 2023 · 5 comments
Assignees
Labels
theme: recursive comparison An issue related to the recursive comparison

Comments

@mikehaertl
Copy link

Describe the bug

When comparingOnlyFields() is used on a list of objects to recursively compare object properties it never reports a failure.

I would have expected it to behave like a complement to ignoringFields() (which works as expected on a list of objects).

  • assertj core version: 3.24.2
  • java version: Temurin-17.0.6+10 (build 17.0.6+10)
  • test framework version: junit-jupiter:5.9.1

Test case reproducing the bug

package foo;

import java.util.Arrays;
import java.util.List;

import org.junit.jupiter.api.Test;

import static org.assertj.core.api.Assertions.assertThat;

class FooTest {

    public class Person {
        String firstname;
        String lastname;

        public Person(String firstname, String lastname) {
            this.firstname = firstname;
            this.lastname = lastname;
        }
    }

    @Test
    public void listExample() {
        Person foo = new Person("Foo First", "Foo Last");
        Person bar = new Person("Bar First", "Bar Last");

        Person expectedFoo = new Person("Foo First", "wrong");
        Person expectedBar = new Person("Bar First", "wrong");

        List<Person> people = Arrays.asList(foo, bar);
        List<Person> expectedPeople = Arrays.asList(expectedFoo, expectedBar);

        // Works
        assertThat(people)
                .usingRecursiveComparison()
                .ignoringFields("lastname")
                .isEqualTo(expectedPeople);

        // Fails as expected
        assertThat(people)
                .usingRecursiveComparison()
                .ignoringFields("firstname")
                .isEqualTo(expectedPeople);


        // Should fail - but works!
        assertThat(people)
                .usingRecursiveComparison()
                .comparingOnlyFields("lastname")
                .isEqualTo(expectedPeople);

        // Should also fail - but works!
        assertThat(people)
                .usingRecursiveComparison()
                .comparingOnlyFields("bla", "blub")
                .isEqualTo(expectedPeople);

    }
}
@aindriu-aiven
Copy link
Contributor

I was able to replicate the behavior on tags/assertj-build-3.24.2 where both of the below pass.
// Should fail - but works!
assertThat(people)
.usingRecursiveComparison()
.comparingOnlyFields("lastname")
.isEqualTo(expectedPeople);

    // Should also fail - but works!
    assertThat(people)
            .usingRecursiveComparison()
            .comparingOnlyFields("bla", "blub")
            .isEqualTo(expectedPeople);

But the first one is working correctly on main and so I believe it has already been fixed.
I do think that the second test case above should fail, if a field that does not exist is entered into the comparingOnlyFields as i would think spelling mistakes could be quiet common and could lead to a lot of silently failing tests.

I"d like to pick this issue up if the assertj team see the benefit in it?

@joel-costigliola
Copy link
Member

joel-costigliola commented Jul 31, 2023

Thanks for checking on main @aindriu-aiven, I agree that the recursive comparison should fail if comparingOnlyFields is given non-existing fields so your PR is welcome.

@aindriu-aiven
Copy link
Contributor

Thanks @joel-costigliola I"ll pick it up!

@scordio scordio added type: bug theme: recursive comparison An issue related to the recursive comparison labels Aug 1, 2023
@aindriu-aiven
Copy link
Contributor

@joel-costigliola
I have opened PR #3137 to check for non-existing fields.
One thing to note is that the following test currently ignores the comparingOnlyFields as it is in a list and a deep compare is instead done to make sure they are the same. I didn"t want to change this behaviour as it seemed like a much larger change that should be discussed first.
// Should also fail - but works!
assertThat(people)
.usingRecursiveComparison()
.comparingOnlyFields("bla", "blub")
.isEqualTo(expectedPeople);

@joel-costigliola
Copy link
Member

Integrated thanks @aindriu-aiven !

@scordio scordio removed the type: bug label Oct 2, 2024
@scordio scordio marked this as a duplicate of #3270 Dec 21, 2024
@scordio scordio changed the title comparingOnlyFields gives false positive on iterable objects comparingOnlyFields gives false positive on Iterable objects Dec 21, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
theme: recursive comparison An issue related to the recursive comparison
Projects
None yet
Development

No branches or pull requests

4 participants