rspec/rules/S899/java/rule.adoc

51 lines
1.5 KiB
Plaintext

When the return value of a function call contain the operation status code, this value should be tested to make sure the operation completed successfully.
This rule raises an issue when the return values of the following are ignored:
* ``++java.io.File++`` operations that return a status code (except ``++mkdirs++``)
* ``++Iterator.hasNext()++``
* ``++Enumeration.hasMoreElements()++``
* ``++Lock.tryLock()++``
* non-void ``++Condition.await*++`` methods
* ``++CountDownLatch.await(long, TimeUnit)++``
* ``++Semaphore.tryAcquire++``
* ``++BlockingQueue++``: ``++offer++``, ``++remove++``
== Noncompliant Code Example
----
public void doSomething(File file, Lock lock) {
file.delete(); // Noncompliant
// ...
lock.tryLock(); // Noncompliant
}
----
== Compliant Solution
----
public void doSomething(File file, Lock lock) {
if (!lock.tryLock()) {
// lock failed; take appropriate action
}
if (!file.delete()) {
// file delete failed; take appropriate action
}
}
----
== See
* https://wiki.sei.cmu.edu/confluence/x/xzdGBQ[CERT, EXP00-J.] - Do not ignore values returned by methods
* https://wiki.sei.cmu.edu/confluence/x/TTZGBQ[CERT, FIO02-J.] - Detect and handle file-related errors
* http://cwe.mitre.org/data/definitions/754[MITRE, CWE-754] - Improper Check for Unusual Exceptional Conditions
ifdef::env-github,rspecator-view[]
'''
== Comments And Links
(visible only on this page)
include::comments-and-links.adoc[]
endif::env-github,rspecator-view[]