add unittest for FunctionAttributeCheck
This commit is contained in:
parent
14ba4af4bd
commit
ba4617efac
|
@ -6,6 +6,7 @@
|
||||||
module dscanner.analysis.function_attributes;
|
module dscanner.analysis.function_attributes;
|
||||||
|
|
||||||
import dscanner.analysis.base;
|
import dscanner.analysis.base;
|
||||||
|
import dscanner.analysis.helpers;
|
||||||
import dparse.ast;
|
import dparse.ast;
|
||||||
import dparse.lexer;
|
import dparse.lexer;
|
||||||
import std.stdio;
|
import std.stdio;
|
||||||
|
@ -147,3 +148,39 @@ private:
|
||||||
enum string ABSTRACT_MESSAGE = "'abstract' attribute is redundant in interface declarations";
|
enum string ABSTRACT_MESSAGE = "'abstract' attribute is redundant in interface declarations";
|
||||||
enum string KEY = "dscanner.confusing.function_attributes";
|
enum string KEY = "dscanner.confusing.function_attributes";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unittest
|
||||||
|
{
|
||||||
|
import dscanner.analysis.config : StaticAnalysisConfig, Check, disabledConfig;
|
||||||
|
|
||||||
|
StaticAnalysisConfig sac = disabledConfig();
|
||||||
|
sac.function_attribute_check = Check.enabled;
|
||||||
|
assertAnalyzerWarnings(q{
|
||||||
|
int foo() @property { return 0; }
|
||||||
|
const int confusingConst() { return 0; } // [warn]: 'const' is not an attribute of the return type. Place it after the parameter list to clarify.
|
||||||
|
|
||||||
|
class ClassName {
|
||||||
|
int bar() @property { return 0; } // [warn]: Zero-parameter '@property' function should be marked 'const', 'inout', or 'immutable'.
|
||||||
|
int barConst() const @property { return 0; }
|
||||||
|
}
|
||||||
|
|
||||||
|
struct StructName {
|
||||||
|
int bar() @property { return 0; } // [warn]: Zero-parameter '@property' function should be marked 'const', 'inout', or 'immutable'.
|
||||||
|
int barConst() const @property { return 0; }
|
||||||
|
}
|
||||||
|
|
||||||
|
union UnionName {
|
||||||
|
int bar() @property { return 0; } // [warn]: Zero-parameter '@property' function should be marked 'const', 'inout', or 'immutable'.
|
||||||
|
int barConst() const @property { return 0; }
|
||||||
|
}
|
||||||
|
|
||||||
|
interface InterfaceName {
|
||||||
|
int bar() @property; // [warn]: Zero-parameter '@property' function should be marked 'const', 'inout', or 'immutable'.
|
||||||
|
int barConst() const @property;
|
||||||
|
|
||||||
|
abstract int method(); // [warn]: 'abstract' attribute is redundant in interface declarations
|
||||||
|
}
|
||||||
|
}c, sac);
|
||||||
|
|
||||||
|
stderr.writeln("Unittest for FunctionAttributeCheck passed.");
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue