Why does Scrutinizer say "duplicate code" when code is totally different?

416 views Asked by At

Why does Scrutinizer say "duplicate code" when these two methods are totally different? Is this a false-positive or does Scrutinizer indeed want to see this in a more abstract kind of way?

enter image description here

2

There are 2 answers

0
Fabian Streitel On

My guess is that they do what is called "normalization", i.e. the text is split into smaller parts (called tokens) and then some of these tokens are replaced with different text to make them all the same. For example, all numbers and strings are normalized to be the same number/string.

This makes sure that you can find clones that only differ in literals, which is helpful, because it usually means that you can extract a utility method that takes these differing literals as a parameter and thus reduce the redundancy in your code.

So to the clone detector, your code would then look something like this (all uppercase text is normalized):

public function IDENTIFIER($VARIABLE1) {
    $VARIABLE2 = $this->database->prepare(STRING);
    $VARIABLE2->execute(ARRAY_EXPRESSION);
    if ($VARIABLE2->rowCount() == INTEGER) {
        return BOOLEAN;
    }
    return BOOLEAN;
}

Both functions would be normalized to this exact same representation and the clone detector will then pick this up as duplicated code.

The only sensible refactoring I can see for your code would be to extract a helper function that handles preparing and executing the query and returning the row count:

public function executeRowCountQuery($query_string, $query_variables) {
    $query = this->database->prepare($query_string);
    $query->execute($query_variables);
    return $query->rowCount();
}

This might make sense if you have many different queries that are only interested in the row count.

1
ymakux On

It's better to disable the validation at all in .scrutinizer.yml

checks:
    php:
        duplication: false