Annotation Interface CsvFileSource
@CsvFileSource is a repeatable
 ArgumentsSource which is used to load comma-separated value (CSV)
 files from one or more classpath resources() or files().
 The CSV records parsed from these resources and files will be provided as
 arguments to the annotated
 @ParameterizedClass or
 @ParameterizedTest. Note
 that the first record may optionally be used to supply CSV headers (see
 useHeadersInDisplayName()).
 
Any line beginning with a # symbol will be interpreted as a comment
 and will be ignored.
 
The column delimiter (which defaults to a comma (,)) can be customized
 via either delimiter() or delimiterString().
 
The line separator is detected automatically, meaning that any of
 "\r", "\n", or "\r\n" is treated as a line separator.
 
In contrast to the default syntax used in @CsvSource, @CsvFileSource
 uses a double quote (") as its quote character by default, but this can
 be changed via quoteCharacter(). An empty, quoted value ("")
 results in an empty String unless the emptyValue() attribute is
 set; whereas, an entirely empty value is interpreted as a null
 reference. By specifying one or more nullValues() a custom value can be
 interpreted as a null reference (see the User Guide for an example). An
 ArgumentConversionException is thrown if the target type of a null
 reference is a primitive type.
 
NOTE: An unquoted empty value will always be converted to a
 null reference regardless of any custom values configured via the
 nullValues() attribute.
 
Except within a quoted string, leading and trailing whitespace in a CSV
 column is trimmed by default. This behavior can be changed by setting the
 ignoreLeadingAndTrailingWhitespace() attribute to true.
 
Inheritance
This annotation is inherited to subclasses.
- Since:
- 5.0
- See Also:
- 
Optional Element SummaryOptional ElementsModifier and TypeOptional ElementDescriptioncharThe column delimiter character to use when reading the CSV files.The column delimiter string to use when reading the CSV files.The empty value to use when reading the CSV files.The encoding to use when reading the CSV files; must be a valid charset.String[]The CSV files to use as the sources of arguments; must not be empty unlessresources()is non-empty.booleanControls whether leading and trailing whitespace characters of unquoted CSV columns should be ignored.intThe maximum number of characters allowed per CSV column.String[]A list of strings that should be interpreted asnullreferences.intThe number of lines to skip when reading the CSV files.charThe quote character to use for quoted strings.String[]The CSV classpath resources to use as the sources of arguments; must not be empty unlessfiles()is non-empty.booleanConfigures whether the first CSV record should be treated as header names for columns.
- 
Element Details- 
resources
- 
filesString[] filesThe CSV files to use as the sources of arguments; must not be empty unlessresources()is non-empty.- Default:
- {}
 
- 
encodingString encodingThe encoding to use when reading the CSV files; must be a valid charset.Defaults to "UTF-8".- See Also:
 - Default:
- "UTF-8"
 
- 
useHeadersInDisplayNameConfigures whether the first CSV record should be treated as header names for columns.When set to true, the header names will be used in the generated display name for each@ParameterizedClassor@ParameterizedTestinvocation. When using this feature, you must ensure that the display name pattern for@ParameterizedClassor@ParameterizedTestincludes "{arguments}" instead of "{argumentsWithNames}" as demonstrated in the example below.Defaults to false.Example@ParameterizedTest(name = "[{index}] {arguments}") @CsvFileSource(resources = "fruits.csv", useHeadersInDisplayName = true) void test(String fruit, int rank) { // ... }- Since:
- 5.8.2
 - Default:
- false
 
- 
quoteCharacter
- 
delimiterchar delimiterThe column delimiter character to use when reading the CSV files.This is an alternative to delimiterString()and cannot be used in conjunction withdelimiterString().Defaults implicitly to ',', if neither delimiter attribute is explicitly set.- Default:
- '\u0000'
 
- 
delimiterStringString delimiterStringThe column delimiter string to use when reading the CSV files.This is an alternative to delimiter()and cannot be used in conjunction withdelimiter().Defaults implicitly to ",", if neither delimiter attribute is explicitly set.- Since:
- 5.6
 - Default:
- ""
 
- 
numLinesToSkipint numLinesToSkipThe number of lines to skip when reading the CSV files.Typically used to skip header lines. Defaults to 0.- Since:
- 5.1
 - Default:
- 0
 
- 
emptyValueString emptyValueThe empty value to use when reading the CSV files.This value replaces quoted empty strings read from the input. Defaults to "".- Since:
- 5.5
 - Default:
- ""
 
- 
nullValuesString[] nullValuesA list of strings that should be interpreted asnullreferences.For example, you may wish for certain values such as "N/A"or"NIL"to be converted tonullreferences.Please note that unquoted empty values will always be converted to nullreferences regardless of the value of thisnullValuesattribute; whereas, a quoted empty string will be treated as anemptyValue().Defaults to {}.- Since:
- 5.6
 - Default:
- {}
 
- 
maxCharsPerColumn
- 
ignoreLeadingAndTrailingWhitespaceControls whether leading and trailing whitespace characters of unquoted CSV columns should be ignored.Whitespace refers to characters with Unicode code points less than or equal to U+0020, as defined byString.trim().Defaults to true.- Since:
- 5.8
 - Default:
- true
 
 
-