Class: Releasinator::Changelog::Validator
- Inherits:
-
Object
- Object
- Releasinator::Changelog::Validator
- Defined in:
- lib/changelog/validator.rb
Constant Summary collapse
- RELEASE_REGEX =
/\d+\.\d+\.\d+/
Instance Method Summary collapse
- #check_semver_criteria(condition, message) ⇒ Object
- #ends_with_punctuation?(line) ⇒ Boolean
- #fail_punctuation(line) ⇒ Object
-
#initialize(releasinator_config) ⇒ Validator
constructor
A new instance of Validator.
- #starts_with_bullet?(line) ⇒ Boolean
- #validate_changelog_contents(changelog_contents) ⇒ Object
-
#validate_semver(changelog_hash) ⇒ Object
assume changelog_hash is not empty.
- #validate_single_changelog_entry(entry) ⇒ Object
Constructor Details
#initialize(releasinator_config) ⇒ Validator
Returns a new instance of Validator.
12 13 14 |
# File 'lib/changelog/validator.rb', line 12 def initialize(releasinator_config) @releasinator_config = releasinator_config end |
Instance Method Details
#check_semver_criteria(condition, message) ⇒ Object
62 63 64 65 66 67 |
# File 'lib/changelog/validator.rb', line 62 def check_semver_criteria(condition, ) if !condition Printer.fail() abort() end end |
#ends_with_punctuation?(line) ⇒ Boolean
133 134 135 |
# File 'lib/changelog/validator.rb', line 133 def ends_with_punctuation?(line) line.match /.*[\!,\?:\.]$/ end |
#fail_punctuation(line) ⇒ Object
137 138 139 140 |
# File 'lib/changelog/validator.rb', line 137 def fail_punctuation(line) Printer.fail("'#{line}' is invalid. Bulleted points should end in punctuation and no trailing line whitespace.") abort() end |
#starts_with_bullet?(line) ⇒ Boolean
129 130 131 |
# File 'lib/changelog/validator.rb', line 129 def starts_with_bullet?(line) line.match /^\s*\*\s+.*$/ end |
#validate_changelog_contents(changelog_contents) ⇒ Object
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 |
# File 'lib/changelog/validator.rb', line 69 def validate_changelog_contents(changelog_contents) # Modified version of Vandamme::Parser::DEFAULT_REGEX to disallow versions with leading alpha characters changelog_regex = Regexp.new('^#{0,3} ?(v?[\d\.-]+\.[\w\d\.-]+[a-zA-Z0-9])(?: \W (\w+ \d{1,2}(?:st|nd|rd|th)?,\s\d{4}|\d{4}-\d{2}-\d{2}|\w+))?\n?[=-]*') parser = Vandamme::Parser.new(changelog: changelog_contents, version_header_exp: changelog_regex, format: 'markdown') changelog_hash = parser.parse if changelog_hash.empty? Printer.fail("Unable to find any releases in the CHANGELOG.md. Please check that the formatting is correct.") abort() end Printer.success("Found " + changelog_hash.count.to_s.bold + " release(s) in CHANGELOG.md.") validate_semver(changelog_hash) changelog_hash.each { |release, changelog| validate_single_changelog_entry(changelog) } latest_release, latest_release_changelog = changelog_hash.first CurrentRelease.new(latest_release, latest_release_changelog) end |
#validate_semver(changelog_hash) ⇒ Object
assume changelog_hash is not empty
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
# File 'lib/changelog/validator.rb', line 17 def validate_semver(changelog_hash) latest_release, latest_release_changelog = changelog_hash.first # extract prefix from first release to use on all subsequent releases latest_release_prefix = latest_release.partition(RELEASE_REGEX)[0] newer_version = nil changelog_hash.each do |key,value| prefix, version, suffix = key.partition(RELEASE_REGEX) puts "Checking version with prefix:'#{prefix}', version:'#{version}', suffix:'#{suffix}'." if @releasinator_config[:verbose] if prefix != latest_release_prefix Printer.fail("version #{key} does not start with extracted prefix '#{latest_release_prefix}'.") abort() end older_version = Semantic::Version.new version if nil != newer_version version_comp = newer_version <=> older_version if version_comp < 0 Printer.fail("Semver releases out of order: #{older_version} should be smaller than #{newer_version}") abort() elsif version_comp == 0 # this case cannot be found with Vandamme library because 2 versions in a row get overwritten in the underlying hash if suffix.empty? Printer.fail("2 semver releases in a row without a suffix (like -beta, -rc1, etc...) is not allowed.") abort() end else error_suffix = "version increment error - comparing #{newer_version} to #{older_version} does not pass semver validation." # validate the next sequence in semver if newer_version.major == older_version.major if newer_version.minor == older_version.minor check_semver_criteria(newer_version.patch == older_version.patch + 1, "patch #{error_suffix}") else check_semver_criteria(newer_version.minor == older_version.minor + 1 && newer_version.patch == 0, "minor #{error_suffix}") end else check_semver_criteria(newer_version.major == older_version.major + 1 && newer_version.minor == 0 && newer_version.patch == 0, "major #{error_suffix}") end end end newer_version = older_version end end |
#validate_single_changelog_entry(entry) ⇒ Object
92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 |
# File 'lib/changelog/validator.rb', line 92 def validate_single_changelog_entry(entry) previous_line_in_progress = nil lines = entry.chomp.split(/\r?\n/) lines.each{ |line| if starts_with_bullet? line if previous_line_in_progress fail_punctuation(previous_line_in_progress) elsif ends_with_punctuation? line # self-contained line is a-ok, and the usual use-case previous_line_in_progress = nil else # line starts with bullet, but did not end with punctuation previous_line_in_progress = line end elsif previous_line_in_progress # does not start with bullet, and is continuing from previous line if ends_with_punctuation? line # multi-line ending with punctuation is ok! previous_line_in_progress = nil else # middle of multi-line - neither starts with bullet, nor ends with punctuation. previous_line_in_progress = line end else # don't care about empty or code lines interspersed in a changelog entry end } # the last line may not be clean. Handle it. if previous_line_in_progress fail_punctuation(previous_line_in_progress) end end |