The EiffelSourceChangeCreatedEvent declares that a change to sources has been made, but not yet submitted (see EiffelSourceChangeSubmittedEvent). This can be used to represent a change done on a private branch, undergoing review or made in a forked repository. Unlike EiffelSourceChangeSubmittedEvent, EiffelSourceChangeCreatedEvent describes the change in terms of who authored it and which issues it addressed.
Where changes are integrated (or "submitted") directly on a shared branch of interest (e.g. "master", "dev" or "mainline") both EiffelSourceChangeCreatedEvent and EiffelSourceChangeSubmittedEvent are sent together.
Type: Object
Required: No
Description: The author of the change.
Type: String
Required: No
Description: The name of the author.
Type: String
Required: No
Description: The email address of the author.
Type: String
Required: No
Description: Any identity, username or alias of the author.
Type: String
Required: No
Description: Any group or organization to which the contributor belongs.
Type: Object
Required: No
Description: A summary of the change.
Type: Integer
Required: No
Description: The number of inserted lines in the change.
Type: Integer
Required: No
Description: The number of deleted lines in the change.
Type: String
Required: No
Description: A URI to a list of files changed, on JSON String array format.
Type: String
Required: No
Description: A URI to further details about the change. These details are not assumed to be on any standardized format, and may be intended for human and/or machine consumption. Examples include e.g. Gerrit patch set descriptions or GitHub commit pages. It is recommended to also include data.change.tracker to provide a hint as to the nature of the linked details.
Type: String
Required: No
Description: The name of the tracker, if any, of the change. Examples include e.g. Gerrit or GitHub.
Type: String
Required: No
Description: The unique identity, if any, of the change (apart from what is expressed in the identifier object). Examples include e.g. Gerrit Change-Ids or GitHub Pull Requests. It is recommended to also include data.change.tracker to provide a hint as to the nature of the identity.
Type: Object
Required: No
Description: Identifier of a Git change.
Type: String
Required: Yes
Description: The commit identity (hash) of the change.
Type: String
Required: No
Description: The name of the branch where the change was made.
Type: String
Required: No
Description: The name of the repository containing the change.
Type: String
Required: Yes
Description: The URI of the repository containing the change.
Type: Object
Required: No
Description: Identifier of a Subversion change.
Type: Integer
Required: Yes
Description: The revision of the change.
Type: String
Required: Yes
Description: The directory (branch/tag) of the change.
Type: String
Required: No
Description: The name of the repository containing the change.
Type: String
Required: Yes
Description: The URI of the repository containing the change.
Type: Object
Required: No
Description: Identifier of a composite ClearCase change – in other words, not single file commit, but analogous of repository-wide commits of e.g. SVN or Git.
Type: String[]
Required: Yes
Description: The names of the changed ClearCase VOBs.
Type: String
Required: Yes
Description: The branch of the change.
Type: String
Required: Yes
Description: The URI of the relevant ClearCase config spec.
Type: Object
Required: No
Description: Identifier of a Mercurial change.
Type: String
Required: Yes
Description: The commit identity (hash) of the change.
Type: String
Required: No
Description: The branch of the change.
Type: String
Required: No
Description: The name of the repo.
Type: String
Required: Yes
Description: The URI of the repo.
Required: No
Legal targets: EiffelSourceChangeSubmittedEvent
Multiple allowed: No
Description: Identifies the base revision of the created source change.
Required: No
Legal targets: EiffelSourceChangeCreatedEvent
Multiple allowed: Yes
Description: Identifies a latest previous version (there may be more than one in case of merges) of the created source change.
Required: No
Legal targets: EiffelIssueDefinedEvent
Multiple allowed: Yes
Description: Identifies an issue that this event partially resolves. That is, this SCC introduces some change that has advanced an issue towards a resolved state, but not completely resolved.
Required: No
Legal targets: EiffelIssueDefinedEvent
Multiple allowed: Yes
Description: Identifies an issue that this SCC is claiming it has done enough to resolve. This is not an authoritative resolution, only a claim. The issue may or may not change status as a consequence this, e.g. through a successful verification or a manual update on the issue tracker.
Required: No
Legal targets: EiffelIssueDefinedEvent
Multiple allowed: Yes
Description: Identifies an issue which was previously resolved, but that this SCC claims it has made changes to warrant removing the resolved status. For example, if an issue "Feature X" was resolved, but this SCC removed the implmentation that led to "Feature X" being resolved, that issue should no longer be considered resolved.
Required: No
Legal targets: Any
Multiple allowed: Yes
Description: Identifies a cause of the event occurring. SHOULD not be used in conjunction with CONTEXT: individual events providing CAUSE within a larger context gives rise to ambiguity. It is instead recommended to let the root event of the context declare CAUSE.
Required: No
Legal targets: EiffelActivityTriggeredEvent,
EiffelTestSuiteStartedEvent
Multiple allowed: No
Description: Identifies the activity or test suite of which this event constitutes a part.
Required: No
Legal targets: EiffelFlowContextDefinedEvent
Multiple allowed: Yes
Description: Identifies the flow context of the event: which is the continuous integration and delivery flow in which this occurred – e.g. which product, project, track or version this is applicable to.
Type: String
Format: UUID
Required: Yes
Description: The unique identity of the event, generated at event creation.
Type: String
Format: An event type name
Required: Yes
Description: The type of event. This field is required by the recipient of the event, as each event type has a specific meaning and a specific set of members in the data and links objects.
Type: String
Format: Semantic Versioning 2.0.0
Required: Yes
Description: The version of the event type. This field is required by the recipient of the event to interpret the contents. Please see Versioning for more information.
Type: Integer
Format: UNIX Epoch time, in milliseconds.
Required: Yes
Description: The event creation timestamp.
Type: String[]
Format: Free text
Required: No
Description: Any tags or keywords associated with the events, for searchability purposes.
Type: Object
Format:
Required: No
Description: A description of the source of the event. This object is primarily for traceability purposes, and while optional, some form of identification of the source is HIGHLY RECOMMENDED. It offers multiple methods of identifying the source of the event, techniques which may be select from based on the technology domain and needs in any particular use case.
Type: String
Format: Free text
Required: No
Description: Identifies the domain that produced an event. A domain is an infrastructure topological concept, which may or may not corresponds to an organization or product structures. A good example would be Java packages notation, ex. com.mycompany.product.component or mycompany.site.division. Also, keep in mind that all names are more or less prone to change. Particularly, it is recommended to avoid organizational names or site names, as organizations tend to be volatile and development is easily relocated. Relatively speaking, product and component names tend to be more stable and are therefore encouraged, while code names may be an option. You need to decide what is the most sensible option in your case.
Type: String
Format: Hostname
Required: No
Description: The hostname of the event sender.
Type: String
Format: Free text
Required: No
Description: The name of the event sender.
Type: String
Format: purl specification
Required: No
Description: The identity of the serializer software used to construct the event, in purl format.
Type: String
Format: URI
Required: No
Description: The URI of, related to or describing the event sender.
Type: Object
Format:
Required: No
Description: An optional object for enclosing security related information, particularly supporting data integrity. See Security for further information.
Type: Object
Format:
Required: No
Description: An optional object for properties supporting the Strong Distribution Model. Note that this only addressed the integrity of the Eiffel event, not its confidentiality or availability.
Type: String
Format:
Required: Yes
Description: The identity of the author of the event. This property is intended to enable the recipient to look up the appropriate public key for decrypting the digest and thereby verifying author identity and data integrity. The format of the author identity varies depending on the key infrastructure solution used. Note that this requires the presence of a Trusted Authority (TA) which the recipient can query for the correct public key. The identity and location of the TA must never be included in the event itself, as this would compromise the security of the solution.
Type: String
Format:
Required: Yes
Description: The encrypted digest. The cryptographic hash function and the decryption algorithm to use, similarly to the Trusted Authority (TA), must be known to the recipient. Note that the digest of the entire event is affected by the value of this property. For this reason the input to the hash function SHALL be the entire event unaltered in all parts except for this property, which SHALL be replaced by an empty string.
Version | Introduced in | Changes |
---|---|---|
3.0.0 | Current version | Introduced purl identifiers instead of GAVs (see Issue 182) |
2.0.0 | 0706840 | Replaced data.issues with links |
1.1.0 | edition-toulouse | Multiple links of type FLOW_CONTEXT allowed. |
1.0.0 | edition-bordeaux | Initial version. |