mirror of
https://github.com/discourse/discourse.git
synced 2025-02-25 18:55:32 -06:00
DEV: Add options to theme install rake task - more options (#9394)
This commit is contained in:
committed by
GitHub
parent
2aaf5cb2b8
commit
f07c4a781c
@@ -8,75 +8,136 @@ describe ThemesInstallTask do
|
||||
Discourse::Application.load_tasks
|
||||
end
|
||||
|
||||
let(:github_repo) { 'https://github.com/example/theme.git' }
|
||||
let(:branch) { 'master' }
|
||||
|
||||
describe '.new' do
|
||||
context 'with url' do
|
||||
subject { described_class.new(github_repo) }
|
||||
|
||||
it 'configures the url' do
|
||||
expect(subject.url).to eq github_repo
|
||||
def setup_git_repo(files)
|
||||
dir = Dir.tmpdir
|
||||
repo_dir = "#{dir}/#{SecureRandom.hex}"
|
||||
`mkdir #{repo_dir}`
|
||||
`cd #{repo_dir} && git init . `
|
||||
`cd #{repo_dir} && git config user.email 'someone@cool.com'`
|
||||
`cd #{repo_dir} && git config user.name 'The Cool One'`
|
||||
`cd #{repo_dir} && git config commit.gpgsign 'false'`
|
||||
files.each do |name, data|
|
||||
FileUtils.mkdir_p(Pathname.new("#{repo_dir}/#{name}").dirname)
|
||||
File.write("#{repo_dir}/#{name}", data)
|
||||
`cd #{repo_dir} && git add #{name}`
|
||||
end
|
||||
`cd #{repo_dir} && git commit -am 'first commit'`
|
||||
repo_dir
|
||||
end
|
||||
|
||||
it 'initializes without options' do
|
||||
expect(subject.options).to eq({})
|
||||
THEME_NAME = "awesome theme"
|
||||
|
||||
def about_json(love_color: "FAFAFA", tertiary_low_color: "FFFFFF", color_scheme_name: "Amazing", about_url: "https://www.site.com/about", component: false)
|
||||
<<~JSON
|
||||
{
|
||||
"name": "#{THEME_NAME}",
|
||||
"about_url": "#{about_url}",
|
||||
"license_url": "https://www.site.com/license",
|
||||
"theme_version": "1.0",
|
||||
"minimum_discourse_version": "1.0.0",
|
||||
"assets": {
|
||||
"font": "assets/font.woff2"
|
||||
},
|
||||
"component": "#{component}",
|
||||
"color_schemes": {
|
||||
"#{color_scheme_name}": {
|
||||
"love": "#{love_color}",
|
||||
"tertiary-low": "#{tertiary_low_color}"
|
||||
}
|
||||
},
|
||||
"modifiers": {
|
||||
"serialize_topic_excerpts": true
|
||||
}
|
||||
}
|
||||
JSON
|
||||
end
|
||||
|
||||
let :scss_data do
|
||||
"@font-face { font-family: magic; src: url($font)}; body {color: $color; content: $name;}"
|
||||
end
|
||||
|
||||
let :theme_repo do
|
||||
setup_git_repo(
|
||||
"about.json" => about_json,
|
||||
"desktop/desktop.scss" => scss_data,
|
||||
"scss/oldpath.scss" => ".class2{color:blue}",
|
||||
"stylesheets/file.scss" => ".class1{color:red}",
|
||||
"stylesheets/empty.scss" => "",
|
||||
"javascripts/discourse/controllers/test.js.es6" => "console.log('test');",
|
||||
"common/header.html" => "I AM HEADER",
|
||||
"common/random.html" => "I AM SILLY",
|
||||
"common/embedded.scss" => "EMBED",
|
||||
"assets/font.woff2" => "FAKE FONT",
|
||||
"settings.yaml" => "boolean_setting: true",
|
||||
"locales/en.yml" => "sometranslations"
|
||||
)
|
||||
end
|
||||
|
||||
let :component_repo do
|
||||
setup_git_repo(
|
||||
"about.json" => about_json(component: true),
|
||||
"desktop/desktop.scss" => scss_data,
|
||||
"scss/oldpath.scss" => ".class2{color:blue}",
|
||||
"stylesheets/file.scss" => ".class1{color:red}",
|
||||
"stylesheets/empty.scss" => "",
|
||||
"javascripts/discourse/controllers/test.js.es6" => "console.log('test');",
|
||||
"common/header.html" => "I AM HEADER",
|
||||
"common/random.html" => "I AM SILLY",
|
||||
"common/embedded.scss" => "EMBED",
|
||||
"assets/font.woff2" => "FAKE FONT",
|
||||
"settings.yaml" => "boolean_setting: true",
|
||||
"locales/en.yml" => "sometranslations"
|
||||
)
|
||||
end
|
||||
|
||||
after do
|
||||
`rm -fr #{theme_repo}`
|
||||
`rm -fr #{component_repo}`
|
||||
end
|
||||
|
||||
it 'gracefully fails' do
|
||||
ThemesInstallTask.install("nothing": "fail!")
|
||||
expect(Theme.where(name: "fail!").exists?).to eq(false)
|
||||
end
|
||||
|
||||
describe "no options" do
|
||||
it 'installs a theme' do
|
||||
ThemesInstallTask.install("some_theme": theme_repo)
|
||||
expect(Theme.where(name: THEME_NAME).exists?).to eq(true)
|
||||
end
|
||||
end
|
||||
|
||||
context 'with options' do
|
||||
subject { described_class.new(options) }
|
||||
let(:options) { { 'url' => github_repo, 'branch' => branch } }
|
||||
|
||||
it 'configures the url' do
|
||||
expect(subject.url).to eq github_repo
|
||||
describe "with options" do
|
||||
it 'installs a theme from only a url' do
|
||||
ThemesInstallTask.install({ "some_theme": { "url": theme_repo } })
|
||||
expect(Theme.where(name: THEME_NAME).exists?).to eq(true)
|
||||
end
|
||||
|
||||
it 'initializes options' do
|
||||
expect(subject.options).to eq("url" => github_repo, "branch" => branch)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe '#theme_exists?' do
|
||||
let(:theme) { Fabricate(:theme) }
|
||||
subject { described_class.new(options) }
|
||||
|
||||
context 'without branch' do
|
||||
let(:options) { github_repo }
|
||||
|
||||
it 'returns true when a branchless theme exists' do
|
||||
theme.create_remote_theme(remote_url: github_repo)
|
||||
expect(subject.theme_exists?).to be true
|
||||
it 'does not set the theme to default if the key/value is not present' do
|
||||
ThemesInstallTask.install({ "some_theme": { "url": theme_repo } })
|
||||
theme = Theme.find_by(name: THEME_NAME)
|
||||
expect(theme.default?).to eq(false)
|
||||
end
|
||||
|
||||
it 'returns false when the url exists but with a branch' do
|
||||
theme.create_remote_theme(remote_url: github_repo, branch: branch)
|
||||
expect(subject.theme_exists?).to be false
|
||||
it 'sets the theme to default if the key/value is true' do
|
||||
ThemesInstallTask.install({ "some_theme": { "url": theme_repo, default: true } })
|
||||
theme = Theme.find_by(name: THEME_NAME)
|
||||
expect(theme.default?).to eq(true)
|
||||
end
|
||||
|
||||
it 'returns false when it doesnt exist' do
|
||||
theme.create_remote_theme(remote_url: 'https://github.com/example/different_theme.git')
|
||||
expect(subject.theme_exists?).to be false
|
||||
end
|
||||
end
|
||||
|
||||
context 'with branch' do
|
||||
let(:options) { { 'url' => github_repo, 'branch' => branch } }
|
||||
|
||||
it 'returns false when a branchless theme exists' do
|
||||
theme.create_remote_theme(remote_url: github_repo)
|
||||
expect(subject.theme_exists?).to be false
|
||||
it 'installs theme components, but does not add them to themes' do
|
||||
ThemesInstallTask.install({ "some_theme": { "url": component_repo } })
|
||||
theme = Theme.find_by(name: THEME_NAME)
|
||||
expect(theme.component).to eq(true)
|
||||
end
|
||||
|
||||
it 'returns true when the url exists with a branch' do
|
||||
theme.create_remote_theme(remote_url: github_repo, branch: branch)
|
||||
expect(subject.theme_exists?).to be true
|
||||
end
|
||||
|
||||
it 'returns false when it doesnt exist' do
|
||||
theme.create_remote_theme(remote_url: 'https://github.com/example/different_theme.git')
|
||||
expect(subject.theme_exists?).to be false
|
||||
it 'adds component to all themes if "add_to_all_themes" is true' do
|
||||
ThemesInstallTask.install({ "some_theme": { "url": component_repo, add_to_all_themes: true } })
|
||||
theme = Theme.find_by(name: THEME_NAME)
|
||||
Theme.where(component: false).each do |parent_theme|
|
||||
expect(ChildTheme.find_by(parent_theme_id: parent_theme.id, child_theme_id: theme.id).nil?).to eq(false)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user