CodeQL documentation

Duplicate property

ID: js/duplicate-property
Kind: problem
Security severity: 
Severity: warning
Precision: very-high
   - maintainability
   - external/cwe/cwe-563
Query suites:
   - javascript-security-and-quality.qls

Click to see the query in the CodeQL repository

In ECMAScript 2015 and above, as well as ECMAScript 5 non-strict mode, an object literal may define the same property multiple times, with later definitions overwriting earlier ones. If all definitions assign the same value to the property, this will not to lead to problems at runtime, but it makes the code harder to read and maintain.


Eliminate the spurious redefinition.


In the following example, the object literal passed to method css has two definitions of property backgroundColor, both setting it to value "orange".

  backgroundColor: "orange",
  fontWeight: "bold",
  backgroundColor: "orange"

The second definition is spurious and should be removed:

  backgroundColor: "orange",
  fontWeight: "bold"


  • Ecma International, ECMAScript Language Definition, 5.1 Edition, Annex C. ECMA, 2011.

  • Ecma International, ECMAScript Language Definition, 6th Edition, Annex E. ECMA, 2015.

  • Common Weakness Enumeration: CWE-563.

  • © GitHub, Inc.
  • Terms
  • Privacy