1 # frozen_string_literal: true
3 require 'puppet_litmus/rake_tasks' if Bundler.rubygems.find_name('puppet_litmus').any?
4 require 'puppetlabs_spec_helper/rake_tasks'
5 require 'puppet-syntax/tasks/puppet-syntax'
6 require 'puppet_blacksmith/rake_tasks' if Bundler.rubygems.find_name('puppet-blacksmith').any?
7 require 'github_changelog_generator/task' if Bundler.rubygems.find_name('github_changelog_generator').any?
8 require 'puppet-strings/tasks' if Bundler.rubygems.find_name('puppet-strings').any?
11 return unless Rake.application.top_level_tasks.include? "changelog"
12 returnVal = nil || JSON.load(File.read('metadata.json'))['author']
13 raise "unable to find the changelog_user in .sync.yml, or the author in metadata.json" if returnVal.nil?
14 puts "GitHubChangelogGenerator user:#{returnVal}"
19 return unless Rake.application.top_level_tasks.include? "changelog"
23 metadata_source = JSON.load(File.read('metadata.json'))['source']
24 metadata_source_match = metadata_source && metadata_source.match(%r{.*\/([^\/]*?)(?:\.git)?\Z})
26 metadata_source_match && metadata_source_match[1]
29 raise "unable to find the changelog_project in .sync.yml or calculate it from the source in metadata.json" if returnVal.nil?
31 puts "GitHubChangelogGenerator project:#{returnVal}"
35 def changelog_future_release
36 return unless Rake.application.top_level_tasks.include? "changelog"
37 returnVal = "v%s" % JSON.load(File.read('metadata.json'))['version']
38 raise "unable to find the future_release (version) in metadata.json" if returnVal.nil?
39 puts "GitHubChangelogGenerator future_release:#{returnVal}"
43 PuppetLint.configuration.send('disable_relative')
45 if Bundler.rubygems.find_name('github_changelog_generator').any?
46 GitHubChangelogGenerator::RakeTask.new :changelog do |config|
47 raise "Set CHANGELOG_GITHUB_TOKEN environment variable eg 'export CHANGELOG_GITHUB_TOKEN=valid_token_here'" if Rake.application.top_level_tasks.include? "changelog" and ENV['CHANGELOG_GITHUB_TOKEN'].nil?
48 config.user = "#{changelog_user}"
49 config.project = "#{changelog_project}"
50 config.future_release = "#{changelog_future_release}"
51 config.exclude_labels = ['maintenance']
52 config.header = "# Change log\n\nAll notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](http://semver.org)."
53 config.add_pr_wo_labels = true
55 config.merge_prefix = "### UNCATEGORIZED PRS; LABEL THEM ON GITHUB"
56 config.configure_sections = {
58 "prefix" => "### Changed",
59 "labels" => ["backwards-incompatible"],
62 "prefix" => "### Added",
63 "labels" => ["enhancement", "feature"],
66 "prefix" => "### Fixed",
67 "labels" => ["bug", "documentation", "bugfix"],
72 desc 'Generate a Changelog from GitHub'
75 The changelog tasks depends on recent features of the github_changelog_generator gem.
76 Please manually add it to your .sync.yml for now, and run `pdk update`:
81 - gem: 'github_changelog_generator'
83 condition: "Gem::Version.new(RUBY_VERSION.dup) >= Gem::Version.new('2.3.0')"