Attachment Element/en
Inhaltsverzeichnis
Introduction[Bearbeiten]
An attachment allows managing any file together with a testsuite. These files will be packed and bundeled into the testsuite (which is technically a ZIP-file). Attachments are important, if test data sets or configuration files have to be managed together with the testsuite. They can also contain files which are meant for other users like documentation or specifications and explanations concerning test runs. All attachment will be unpacked in a separate "attachments" folder under a project-specific directory when the testsuite is loaded.
Therefore, an attachment's filename should usually consist of the base-filename only (i.e. do not use a full absolute path). The attachments behavior is configurable to either provide the filename or its contents at its output pin. The default setting is to generate a filename. Thus, to get the full path of an attachment, make sure that the output representation is set to "pathName" and connect the attachment step's output to whichever step needs the path. Notice that all of the attachments filenames must be distinct. When copy-pasting or dragging attachments into the tree, expecco may silently change the filename, if another attachment already exists by that filename. Also notice, that the underlying filename may be different from its name shown in the tree.
On most situations, you will not need the file's actual path, but its contents instead. Choose an appropriate output representation from the steps context menu. Typically, this will be one of "string", "utf8 string" or "binary". See the list below for details.
Attachments can be also added to the project tree via drag and drop of any file into the expecco tree area. They can be modified in the builtin attachment editor or by an external tool (Excel, Notepad etc.).
Use of Absolute Filenames[Bearbeiten]
If an absolute path is given as filename, the underlying file is assumed to be generated by some other program (possibly on the fly, during execution). These files are considered "extern to expecco", and are not saved with the ".elf" file. Use this, to access configuration data which is supposed to be already installed on the testhost, or which is created dynamically, for example due to the execution of a supporting external program.
Because absolute pathnames are considered harmful (you may forget to save/restore/install) them, the project tree's error-search function includes a "search-for-absolute attachments" checkbox, to quickly locate such attachments.
URL Attachments[Bearbeiten]
These attachments are fetched dynamically during execution time via an HTTP-Get request from the specified URL (other access methods may be added in future versions). A runtime error will be raised, if that file is no longer accessable. URL attachments are therefore somewhat dangerous: your test depends on another external resource. Therefore, it is recommended to fetch the URL once during test-development time, and to add it as a regular attachment to the test suite.
Data Representation[Bearbeiten]
An attachments step's context menu in the diagram editor offers various choices for how the attachment's file should be presented at the steps output pin:
- String
 the file is read into one (posibly big) single-byte string. No decoding is performed. This representation may not be appropriate for utf-8 encoded files, if your intent is to process the contents. However, it is most useful, if the contents is to be passed on to other processing steps, passed to external programs, or to be send out via a socket.
- UTF8 String
 the data is read as a single string, and interpreted as an utf-8 encoded string. The output my be a single-byte or a multi-byte string, depending on the presence of characters with a codepoint > 255.
- StringCollection
 the file is read into a collection of single-byte string lines. No decoding is performed.
- Linewise
 the file is read linewise, and each line is send to the output pin as a separate datum. This will trigger followup actions once for every line in the orignal document.
- Binary
 the file is read into a single bytearray collection. Use this for binary data.
- Bitmap Image
 the file is assumed to contain a bitmap image in one of the supported formats (png, jpg, gif, tiff and many others).
The following representations are only possible with URL attachments. They automatically decode the fetched document into the expecco-internal unicode format, from a number of common document encodings (for example, ISO8859-x, UTF8, ascii, and many other).
- DecodedString (URL Attachment only)
 the url is fetched as a single string, which is converted as specified by the encoding answer (from the HTTP request). The output my be a single-byte (for ascii or ISO8859-1 encodings) or a multi-byte string (for most other encodings, especially for utf-8). Use this if followup actions are to process this data.
- Decoded StringCollection
 Same as stringCollection, but each line is decoded from an encoding as returned by the HTTP request.
- Decoded Linewise
 Same as linewise, but each line is decoded from an encoding as returned by the HTTP request.
Notice, that only URL attachment steps provide an automatic determination of the document's encoding (because it gets this information with the HTTP response). For file documents and very special unsupported encodings, you should set the representation to "binary" and connect the output pin to an explicit convertion action. You may find an appropriate decoder block in the standard library, or write your own as an elementary block.
See Also[Bearbeiten]
For other tree elements see: Tree Elements
