Many other open source initiatives leverage an incubation process for new work items, and this seems to have a desired effect of encouraging new ideas and tracks of work, while at the same time providing clear guidance to the broader community as to what is real and supported, versus what is still in the exploratory/experimental/developmental phases.

Therefore the EdgeX Foundry Project has adopted a lifecycle process as follows:

Projects are in one of five possible states:

Projects may not necessarily move through those states in a linear way and may go through several iterations.

Proposal

Project Proposals shall be submitted to the TSC for review, using a Proposal Template. Proposals that are approved shall enter into an Incubation state, unless they are of a refactoring nature, in which case they will be turned over to the relevant project maintainer(s) to handle as they deem fit.

A Proposal must:

  • have a clear description
  • have a well-defined scope
  • identify committed development resources
  • identify initial maintainers
  • be vendor neutral

Incubation

Approved project proposals enter into Incubation. For new components/modules, a repository will be created under the EdgeX Github org, and optionally under Gerrit and JIRA, if requested. New features/capabilities should be handled through pull requests labeled with tags that identify the project and tag it as “incubator” (and will ideally be capable of being enabled/disabled with feature-flags).

Projects in Incubation may overlap with one another. Entering Incubation is meant to be fairly easy to allow for community exploration of different ideas.

Once a project qualifies to be declared Active, the project’s maintainers can then vote to request a graduation review by the TSC.

Projects seeking to graduate from Incubation must:

  • have fully functional code base
  • have test coverage commensurate with other Active projects
  • have an active and diverse community of developers
  • have a history of releases that follow the Active release process

Entering Incubation does not guarantee that the project will eventually get to Active state. Projects may never get to Active state.

The criteria to exit Incubation are defined in the Incubation Exit Criteria document.

Active

Projects that have successfully exited the Incubation phase are in the Active phase.

Deprecated

Anyone may propose that a project be deprecated, by submitting a rationale and identifying a substitute project/component (if any). The maintainers of the project shall vote on such a request and if it passes, make that recommendation to the TSC. Members of the community that disagree with the request shall make their case before the TSC. The TSC shall consider all points of view and render a final decision to deprecate or not.

Deprecated project will be maintained for a six month period by its community, after which it will be removed from any subsequent formal releases. Notice will be given to the public of the project’s deprecation. After the six-month deprecation period, the project will be labeled End of Life.

End of Life

A project that is no longer actively developed or maintained.

Acknowledgements

The above leverages process utilized by the Hyperledger Project.