Documentation ¶
Index ¶
- Constants
- func MatchesExcludeFilter(msg string) bool
- func ParseReleaseNotesMap(mapPath string) (*[]ReleaseNotesMap, error)
- type Dependencies
- type DirectoryMapProvider
- type DocType
- type Documentation
- type Gatherer
- type Kind
- type MapProvider
- type MoDiff
- type Notes
- type ReleaseNote
- type ReleaseNotes
- type ReleaseNotesByPR
- type ReleaseNotesDataField
- type ReleaseNotesHistory
- type ReleaseNotesMap
- type Result
Constants ¶
const ( DefaultOrg = "kubernetes" DefaultRepo = "kubernetes" )
Variables ¶
This section is empty.
Functions ¶
func MatchesExcludeFilter ¶ added in v0.3.1
MatchesExcludeFilter returns true if the string matches an excluded release note
func ParseReleaseNotesMap ¶ added in v0.4.0
func ParseReleaseNotesMap(mapPath string) (*[]ReleaseNotesMap, error)
ParseReleaseNotesMap Parses a Release Notes Map
Types ¶
type Dependencies ¶ added in v0.3.2
type Dependencies struct {
// contains filtered or unexported fields
}
func NewDependencies ¶ added in v0.3.2
func NewDependencies() *Dependencies
func (*Dependencies) Changes ¶ added in v0.3.2
func (d *Dependencies) Changes(from, to string) (string, error)
Changes collects the dependency change report as markdown between both provided revisions. The function errors if anything went wrong.
func (*Dependencies) ChangesForURL ¶ added in v0.3.2
func (d *Dependencies) ChangesForURL(url, from, to string) (string, error)
Changes collects the dependency change report as markdown between both provided revisions for the specified repository URL. The function errors if anything went wrong.
func (*Dependencies) SetMoDiff ¶ added in v0.3.2
func (d *Dependencies) SetMoDiff(moDiff MoDiff)
SetMoDiff can be used to set the internal MoDiff implementation
type DirectoryMapProvider ¶ added in v0.4.0
type DirectoryMapProvider struct { Path string Maps map[int][]*ReleaseNotesMap }
DirectoryMapProvider is a provider that gets maps from a directory
func (*DirectoryMapProvider) GetMapsForPR ¶ added in v0.4.0
func (mp *DirectoryMapProvider) GetMapsForPR(pr int) (notesMap []*ReleaseNotesMap, err error)
GetMapsForPR get the release notes maps for a specific PR number
type Documentation ¶
type Documentation struct { // A description about the documentation Description string `json:"description,omitempty"` // The url to be linked URL string `json:"url"` // Classifies the link as something special, like a KEP Type DocType `json:"type"` }
func DocumentationFromString ¶
func DocumentationFromString(s string) []*Documentation
type Gatherer ¶ added in v0.2.1
type Gatherer struct { MapProviders []*MapProvider // contains filtered or unexported fields }
func NewGatherer ¶ added in v0.2.2
NewGatherer creates a new notes gatherer
func NewGathererWithClient ¶ added in v0.2.2
NewGathererWithClient creates a new notes gatherer with a specific client
func (*Gatherer) ListReleaseNotes ¶ added in v0.2.1
func (g *Gatherer) ListReleaseNotes() (*ReleaseNotes, error)
ListReleaseNotes produces a list of fully contextualized release notes starting from a given commit SHA and ending at starting a given commit SHA.
func (*Gatherer) ListReleaseNotesV2 ¶ added in v0.8.0
func (g *Gatherer) ListReleaseNotesV2() (*ReleaseNotes, error)
func (*Gatherer) ReleaseNoteForPullRequest ¶ added in v0.16.5
func (g *Gatherer) ReleaseNoteForPullRequest(prNr int) (*ReleaseNote, error)
ReleaseNoteForPullRequest returns a release note from a pull request number. If the release note is blank or
func (*Gatherer) ReleaseNoteFromCommit ¶ added in v0.2.1
func (g *Gatherer) ReleaseNoteFromCommit(result *Result) (*ReleaseNote, error)
ReleaseNoteFromCommit produces a full contextualized release note given a GitHub commit API resource.
type Kind ¶ added in v0.4.0
type Kind string
const ( KindAPIChange Kind = "api-change" KindBug Kind = "bug" KindCleanup Kind = "cleanup" KindDeprecation Kind = "deprecation" KindDesign Kind = "design" KindDocumentation Kind = "documentation" KindFailingTest Kind = "failing-test" KindFeature Kind = "feature" KindFlake Kind = "flake" KindRegression Kind = "regression" KindOther Kind = "Other (Cleanup or Flake)" KindUncategorized Kind = "Uncategorized" )
type MapProvider ¶ added in v0.4.0
type MapProvider interface {
GetMapsForPR(int) ([]*ReleaseNotesMap, error)
}
MapProvider interface that obtains release notes maps from a source
func NewProviderFromInitString ¶ added in v0.4.0
func NewProviderFromInitString(initString string) (MapProvider, error)
NewProviderFromInitString creates a new map provider from an initialization string
type ReleaseNote ¶
type ReleaseNote struct { // Commit is the SHA of the commit which is the source of this note. This is // also effectively a unique ID for release notes. Commit string `json:"commit"` // Text is the actual content of the release note Text string `json:"text"` // Markdown is the markdown formatted note Markdown string `json:"markdown"` // Docs is additional documentation for the release note Documentation []*Documentation `json:"documentation,omitempty"` // Author is the GitHub username of the commit author Author string `json:"author"` // AuthorURL is the GitHub URL of the commit author AuthorURL string `json:"author_url"` // PrURL is a URL to the PR PrURL string `json:"pr_url"` // PrNumber is the number of the PR PrNumber int `json:"pr_number"` // Areas is a list of the labels beginning with area/ Areas []string `json:"areas,omitempty"` // Kinds is a list of the labels beginning with kind/ Kinds []string `json:"kinds,omitempty"` // SIGs is a list of the labels beginning with sig/ SIGs []string `json:"sigs,omitempty"` // Indicates whether or not a note will appear as a new feature Feature bool `json:"feature,omitempty"` // Indicates whether or not a note is duplicated across SIGs Duplicate bool `json:"duplicate,omitempty"` // Indicates whether or not a note is duplicated across Kinds DuplicateKind bool `json:"duplicate_kind,omitempty"` // ActionRequired indicates whether or not the release-note-action-required // label was set on the PR ActionRequired bool `json:"action_required,omitempty"` // DoNotPublish by default represents release-note-none label on GitHub DoNotPublish bool `json:"do_not_publish,omitempty"` // DataFields a key indexed map of data fields DataFields map[string]ReleaseNotesDataField `json:"-"` // IsMapped is set if the note got modified from a map IsMapped bool `json:"is_mapped,omitempty"` // PRBody is the full PR body of the release note PRBody string `json:"pr_body,omitempty"` }
ReleaseNote is the type that represents the total sum of all the information we've gathered about a single release note.
func (*ReleaseNote) ApplyMap ¶ added in v0.4.0
func (rn *ReleaseNote) ApplyMap(noteMap *ReleaseNotesMap, markdownLinks bool) error
ApplyMap Modifies the content of the release using information from
a ReleaseNotesMap
func (*ReleaseNote) ContentHash ¶ added in v0.4.1
func (rn *ReleaseNote) ContentHash() (string, error)
ContentHash returns a sha1 hash derived from the note's content
func (*ReleaseNote) ToNoteMap ¶ added in v0.4.1
func (rn *ReleaseNote) ToNoteMap() (string, error)
ToNoteMap returns the note's content as YAML code for use in a notemap
type ReleaseNotes ¶ added in v0.2.0
type ReleaseNotes struct {
// contains filtered or unexported fields
}
ReleaseNotes is the main struct for collecting release notes
func GatherReleaseNotes ¶ added in v0.3.1
func GatherReleaseNotes(opts *options.Options) (*ReleaseNotes, error)
GatherReleaseNotes creates a new gatherer and collects the release notes afterwards
func NewReleaseNotes ¶ added in v0.4.0
func NewReleaseNotes() *ReleaseNotes
NewReleaseNotes can be used to create a new empty ReleaseNotes struct
func (*ReleaseNotes) ByPR ¶ added in v0.4.0
func (r *ReleaseNotes) ByPR() ReleaseNotesByPR
ByPR returns the ReleaseNotesByPR for the ReleaseNotes
func (*ReleaseNotes) Get ¶ added in v0.4.0
func (r *ReleaseNotes) Get(prNumber int) *ReleaseNote
Get returns the ReleaseNote for the provided prNumber
func (*ReleaseNotes) History ¶ added in v0.4.0
func (r *ReleaseNotes) History() ReleaseNotesHistory
History returns the ReleaseNotesHistory for the ReleaseNotes
func (*ReleaseNotes) Set ¶ added in v0.4.0
func (r *ReleaseNotes) Set(prNumber int, note *ReleaseNote)
Set can be used to set a release note for the provided prNumber
type ReleaseNotesByPR ¶ added in v0.4.0
type ReleaseNotesByPR map[int]*ReleaseNote
ReleaseNotes is a map of PR numbers referencing notes. To avoid needless loops, we need to be able to reference things by PR When we have to merge old and new entries, we want to be able to override the old entries with the new ones efficiently.
type ReleaseNotesDataField ¶ added in v0.4.0
type ReleaseNotesDataField interface{}
ReleaseNotesDataField extra data added to a release note
type ReleaseNotesHistory ¶ added in v0.2.0
type ReleaseNotesHistory []int
ReleaseNotesHistory is the sorted list of PRs in the commit history
type ReleaseNotesMap ¶ added in v0.4.0
type ReleaseNotesMap struct { // Pull request where the note was published PR int `json:"pr"` // SHA of the notes commit Commit string `json:"commit,omitempty" yaml:"commit,omitempty"` ReleaseNote struct { // Text is the actual content of the release note Text *string `json:"text,omitempty" yaml:"text,omitempty"` // Docs is additional documentation for the release note Documentation *[]*Documentation `json:"documentation,omitempty" yaml:"documentation,omitempty"` // Author is the GitHub username of the commit author Author *string `json:"author,omitempty" yaml:"author,omitempty"` // Areas is a list of the labels beginning with area/ Areas *[]string `json:"areas,omitempty" yaml:"areas,omitempty"` // Kinds is a list of the labels beginning with kind/ Kinds *[]string `json:"kinds,omitempty" yaml:"kinds,omitempty"` // SIGs is a list of the labels beginning with sig/ SIGs *[]string `json:"sigs,omitempty" yaml:"sigs,omitempty"` // Indicates whether or not a note will appear as a new feature Feature *bool `json:"feature,omitempty" yaml:"feature,omitempty"` // ActionRequired indicates whether or not the release-note-action-required // label was set on the PR ActionRequired *bool `json:"action_required,omitempty" yaml:"action_required,omitempty"` // DoNotPublish by default represents release-note-none label on GitHub DoNotPublish *bool `json:"do_not_publish,omitempty" yaml:"do_not_publish,omitempty"` } `json:"releasenote"` DataFields map[string]ReleaseNotesDataField `json:"datafields,omitempty" yaml:"datafields,omitempty"` // PRBody is the full original PR body. PRBody *string `json:"pr_body,omitempty" yaml:"pr_body,omitempty"` }
ReleaseNotesMap holds the changes that will be applied to the notes the struct has double annotation because of this: https://play.golang.org/p/C7QM1varozy