Compare commits
125 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e1f85973c1 | ||
|
|
3554806741 | ||
|
|
e4cc308d43 | ||
|
|
78271a9ed4 | ||
|
|
8f67188c19 | ||
|
|
c432b27c92 | ||
|
|
30a3bbb198 | ||
|
|
e7f9358f96 | ||
|
|
750c7773ae | ||
|
|
900277f426 | ||
|
|
208adeef6c | ||
|
|
086828b12f | ||
|
|
c73d556e6f | ||
|
|
357e2f60f2 | ||
|
|
243ba70b33 | ||
|
|
640da07089 | ||
|
|
69c38774fe | ||
|
|
44527850f6 | ||
|
|
8d96b2c31f | ||
|
|
0019e8c61c | ||
|
|
545f5fc3e9 | ||
|
|
5108de20c3 | ||
|
|
9656be1dde | ||
|
|
09890e8048 | ||
|
|
b672b4c526 | ||
|
|
6ca49327c3 | ||
|
|
3d47cc44af | ||
|
|
e8b471ac97 | ||
|
|
0e6915b860 | ||
|
|
0d48e517f8 | ||
|
|
f2469ecaaf | ||
|
|
c8451c7d3f | ||
|
|
d3025a34ca | ||
|
|
17426583e0 | ||
|
|
04c4a4c059 | ||
|
|
6ae0aaa6f9 | ||
|
|
d22361f2ac | ||
|
|
e21e608cca | ||
|
|
238658cf69 | ||
|
|
2a361d86e0 | ||
|
|
294fb3d4ce | ||
|
|
342da7e250 | ||
|
|
9c52108035 | ||
|
|
5b954b93e3 | ||
|
|
b596e063f5 | ||
|
|
965b35b78c | ||
|
|
9551b3acb4 | ||
|
|
27ac1c7782 | ||
|
|
f9d0b69bce | ||
|
|
a91ce82d77 | ||
|
|
d8b5d8163b | ||
|
|
6fca06d341 | ||
|
|
44080829e3 | ||
|
|
651e028d5b | ||
|
|
6f3186df2f | ||
|
|
92c61f928e | ||
|
|
d3cb45f879 | ||
|
|
314e2932fb | ||
|
|
8ee5165ccf | ||
|
|
8f2a9e6703 | ||
|
|
f8a6fb9ce2 | ||
|
|
bf248cd645 | ||
|
|
1563814cb0 | ||
|
|
91770998a7 | ||
|
|
d7aca1025f | ||
|
|
b3298d18c8 | ||
|
|
359147e7e8 | ||
|
|
937f1912d7 | ||
|
|
18c0e32309 | ||
|
|
1518cb1155 | ||
|
|
c5b7dd2918 | ||
|
|
b668b7eda2 | ||
|
|
a595ead2c6 | ||
|
|
cc1ee544c3 | ||
|
|
a0862936e8 | ||
|
|
f91f5743b6 | ||
|
|
eb74b90b42 | ||
|
|
c3c108bd50 | ||
|
|
06975f79f5 | ||
|
|
830106a168 | ||
|
|
aa2dfcc42f | ||
|
|
ed71fd6227 | ||
|
|
fd60528567 | ||
|
|
01934d5b00 | ||
|
|
bba0e3ed7d | ||
|
|
7db0b13d30 | ||
|
|
b1c6c8f835 | ||
|
|
7620f40cb2 | ||
|
|
cf9058be04 | ||
|
|
234532ebef | ||
|
|
ccddbb1316 | ||
|
|
4ef315d4e2 | ||
|
|
9b7fe331f6 | ||
|
|
eeff0b40fb | ||
|
|
0c933c0085 | ||
|
|
a3d94fcca6 | ||
|
|
9fe1d190da | ||
|
|
73981c2e75 | ||
|
|
107dec388e | ||
|
|
1df44aea40 | ||
|
|
3bc623be7c | ||
|
|
123e6cf82d | ||
|
|
5e9d134021 | ||
|
|
0a022fddcc | ||
|
|
f18a4dc16f | ||
|
|
9ac754fd40 | ||
|
|
2667053fde | ||
|
|
8874994feb | ||
|
|
5a8b92f556 | ||
|
|
a65c2e6a1f | ||
|
|
2d0304feb1 | ||
|
|
34fec63234 | ||
|
|
1d5f27f567 | ||
|
|
093db8bdac | ||
|
|
04602efd6e | ||
|
|
3265de0c1d | ||
|
|
e4a428e0c5 | ||
|
|
6cc28450a4 | ||
|
|
a0c7fbacb7 | ||
|
|
b750094934 | ||
|
|
d953a964cd | ||
|
|
aa95ffac82 | ||
|
|
54b2b9b339 | ||
|
|
fede78c337 | ||
|
|
8a41dca46d |
@@ -1,3 +1,8 @@
|
|||||||
|
# 0.9.8
|
||||||
|
* Introduce new commands
|
||||||
|
* `homesick cd`
|
||||||
|
* `homesick open`
|
||||||
|
|
||||||
# 0.9.4
|
# 0.9.4
|
||||||
* Use https protocol instead of git protocol
|
* Use https protocol instead of git protocol
|
||||||
* Introduce new commands
|
* Introduce new commands
|
||||||
|
|||||||
4
Gemfile
4
Gemfile
@@ -8,10 +8,14 @@ gem "thor", ">= 0.14.0"
|
|||||||
group :development do
|
group :development do
|
||||||
gem "rake", ">= 0.8.7"
|
gem "rake", ">= 0.8.7"
|
||||||
gem "rspec", "~> 2.10"
|
gem "rspec", "~> 2.10"
|
||||||
|
gem "guard"
|
||||||
|
gem "guard-rspec"
|
||||||
|
gem "rb-readline", "~> 0.5.0"
|
||||||
gem "jeweler", ">= 1.6.2"
|
gem "jeweler", ">= 1.6.2"
|
||||||
gem "rcov", :platforms => :mri_18
|
gem "rcov", :platforms => :mri_18
|
||||||
gem "simplecov", :platforms => :mri_19
|
gem "simplecov", :platforms => :mri_19
|
||||||
gem "test-construct"
|
gem "test-construct"
|
||||||
|
gem "capture-output", "~> 1.0.0"
|
||||||
if RUBY_VERSION >= '1.9.2'
|
if RUBY_VERSION >= '1.9.2'
|
||||||
gem "rubocop"
|
gem "rubocop"
|
||||||
end
|
end
|
||||||
|
|||||||
9
Guardfile
Normal file
9
Guardfile
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
guard :rspec do
|
||||||
|
watch(%r{^spec/.+_spec\.rb$})
|
||||||
|
watch(%r{^lib/(.+)\.rb$}) { |m| "spec/#{m[1]}_spec.rb" }
|
||||||
|
watch(%r{^lib/homesick/.*\.rb}) { "spec" }
|
||||||
|
watch('spec/spec_helper.rb') { "spec" }
|
||||||
|
|
||||||
|
notification :tmux, display_message: true
|
||||||
|
end
|
||||||
|
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
[](https://travis-ci.org/technicalpickles/homesick)
|
[](https://travis-ci.org/technicalpickles/homesick)
|
||||||
|
|
||||||
A man's home (directory) is his castle, so don't leave home with out it.
|
Your home directory is your castle. Don't leave your dotfiles behind.
|
||||||
|
|
||||||
Homesick is sorta like [rip](http://github.com/defunkt/rip), but for dotfiles. It uses git to clone a repository containing dotfiles, and saves them in `~/.homesick`. It then allows you to symlink all the dotfiles into place with a single command.
|
Homesick is sorta like [rip](http://github.com/defunkt/rip), but for dotfiles. It uses git to clone a repository containing dotfiles, and saves them in `~/.homesick`. It then allows you to symlink all the dotfiles into place with a single command.
|
||||||
|
|
||||||
@@ -27,9 +27,6 @@ With the castle cloned, you can now link its contents into your home dir:
|
|||||||
|
|
||||||
homesick symlink pickled-vim
|
homesick symlink pickled-vim
|
||||||
|
|
||||||
If you use the shorthand syntax for GitHub repositories in your clone, please note you will instead need to run:
|
|
||||||
|
|
||||||
homesick symlink technicalpickles/pickled-vim
|
|
||||||
|
|
||||||
You can remove symlinks anytime when you don't need them anymore
|
You can remove symlinks anytime when you don't need them anymore
|
||||||
|
|
||||||
@@ -51,6 +48,14 @@ To push your castle:
|
|||||||
|
|
||||||
homesick push CASTLE
|
homesick push CASTLE
|
||||||
|
|
||||||
|
To open a terminal in the root of a castle:
|
||||||
|
|
||||||
|
homesick cd CASTLE
|
||||||
|
|
||||||
|
To open your default editor in the root of a castle (the $EDITOR environment variable must be set):
|
||||||
|
|
||||||
|
homesick open CASTLE
|
||||||
|
|
||||||
Not sure what else homesick has up its sleeve? There's always the built in help:
|
Not sure what else homesick has up its sleeve? There's always the built in help:
|
||||||
|
|
||||||
homesick help
|
homesick help
|
||||||
|
|||||||
7
Rakefile
7
Rakefile
@@ -12,9 +12,10 @@ require 'rake'
|
|||||||
require 'jeweler'
|
require 'jeweler'
|
||||||
Jeweler::Tasks.new do |gem|
|
Jeweler::Tasks.new do |gem|
|
||||||
gem.name = "homesick"
|
gem.name = "homesick"
|
||||||
gem.summary = %Q{A man's home is his castle. Never leave your dotfiles behind.}
|
gem.summary = %Q{Your home directory is your castle. Don't leave your dotfiles behind.}
|
||||||
gem.description = %Q{
|
gem.description = %Q{
|
||||||
A man's home (directory) is his castle, so don't leave home with out it.
|
Your home directory is your castle. Don't leave your dotfiles behind.
|
||||||
|
|
||||||
|
|
||||||
Homesick is sorta like rip, but for dotfiles. It uses git to clone a repository containing dotfiles, and saves them in ~/.homesick. It then allows you to symlink all the dotfiles into place with a single command.
|
Homesick is sorta like rip, but for dotfiles. It uses git to clone a repository containing dotfiles, and saves them in ~/.homesick. It then allows you to symlink all the dotfiles into place with a single command.
|
||||||
|
|
||||||
@@ -22,7 +23,7 @@ Jeweler::Tasks.new do |gem|
|
|||||||
gem.email = ["josh@technicalpickles.com", "info@muratayusuke.com"]
|
gem.email = ["josh@technicalpickles.com", "info@muratayusuke.com"]
|
||||||
gem.homepage = "http://github.com/technicalpickles/homesick"
|
gem.homepage = "http://github.com/technicalpickles/homesick"
|
||||||
gem.authors = ["Joshua Nichols", "Yusuke Murata"]
|
gem.authors = ["Joshua Nichols", "Yusuke Murata"]
|
||||||
gem.version = "0.9.5"
|
gem.version = "0.9.7"
|
||||||
gem.license = "MIT"
|
gem.license = "MIT"
|
||||||
# Have dependencies? Add them to Gemfile
|
# Have dependencies? Add them to Gemfile
|
||||||
|
|
||||||
|
|||||||
@@ -5,11 +5,11 @@
|
|||||||
|
|
||||||
Gem::Specification.new do |s|
|
Gem::Specification.new do |s|
|
||||||
s.name = "homesick"
|
s.name = "homesick"
|
||||||
s.version = "0.9.5"
|
s.version = "0.9.8"
|
||||||
|
|
||||||
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
||||||
s.authors = ["Joshua Nichols", "Yusuke Murata"]
|
s.authors = ["Joshua Nichols", "Yusuke Murata"]
|
||||||
s.date = "2013-09-18"
|
s.date = "2013-12-31"
|
||||||
s.description = "\n A man's home (directory) is his castle, so don't leave home with out it.\n\n Homesick is sorta like rip, but for dotfiles. It uses git to clone a repository containing dotfiles, and saves them in ~/.homesick. It then allows you to symlink all the dotfiles into place with a single command. \n\n "
|
s.description = "\n A man's home (directory) is his castle, so don't leave home with out it.\n\n Homesick is sorta like rip, but for dotfiles. It uses git to clone a repository containing dotfiles, and saves them in ~/.homesick. It then allows you to symlink all the dotfiles into place with a single command. \n\n "
|
||||||
s.email = ["josh@technicalpickles.com", "info@muratayusuke.com"]
|
s.email = ["josh@technicalpickles.com", "info@muratayusuke.com"]
|
||||||
s.executables = ["homesick"]
|
s.executables = ["homesick"]
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
# -*- encoding : utf-8 -*-
|
||||||
require 'thor'
|
require 'thor'
|
||||||
|
|
||||||
class Homesick < Thor
|
class Homesick < Thor
|
||||||
@@ -9,7 +10,7 @@ class Homesick < Thor
|
|||||||
|
|
||||||
add_runtime_options!
|
add_runtime_options!
|
||||||
|
|
||||||
GITHUB_NAME_REPO_PATTERN = /\A([A-Za-z_-]+\/[A-Za-z_-]+)\Z/
|
GITHUB_NAME_REPO_PATTERN = /\A([A-Za-z0-9_-]+\/[A-Za-z0-9_-]+)\Z/
|
||||||
SUBDIR_FILENAME = '.homesick_subdir'
|
SUBDIR_FILENAME = '.homesick_subdir'
|
||||||
|
|
||||||
DEFAULT_CASTLE_NAME = 'dotfiles'
|
DEFAULT_CASTLE_NAME = 'dotfiles'
|
||||||
@@ -33,7 +34,7 @@ class Homesick < Thor
|
|||||||
|
|
||||||
ln_s uri, destination
|
ln_s uri, destination
|
||||||
elsif uri =~ GITHUB_NAME_REPO_PATTERN
|
elsif uri =~ GITHUB_NAME_REPO_PATTERN
|
||||||
destination = Pathname.new($1)
|
destination = Pathname.new(uri).basename
|
||||||
git_clone "https://github.com/#{$1}.git", :destination => destination
|
git_clone "https://github.com/#{$1}.git", :destination => destination
|
||||||
elsif uri =~ /%r([^%r]*?)(\.git)?\Z/
|
elsif uri =~ /%r([^%r]*?)(\.git)?\Z/
|
||||||
destination = Pathname.new($1)
|
destination = Pathname.new($1)
|
||||||
@@ -89,9 +90,9 @@ class Homesick < Thor
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
desc 'commit CASTLE', "Commit the specified castle's changes"
|
desc 'commit CASTLE MESSAGE', "Commit the specified castle's changes"
|
||||||
def commit(name = DEFAULT_CASTLE_NAME)
|
def commit(name = DEFAULT_CASTLE_NAME, message = nil)
|
||||||
commit_castle name
|
commit_castle name, message
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -227,6 +228,41 @@ class Homesick < Thor
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
desc "destroy CASTLE", "Delete all symlinks and remove the cloned repository"
|
||||||
|
def destroy(name)
|
||||||
|
check_castle_existance name, "destroy"
|
||||||
|
|
||||||
|
if shell.yes?("This will destroy your castle irreversible! Are you sure?")
|
||||||
|
unlink(name)
|
||||||
|
rm_rf repos_dir.join(name)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
desc "cd CASTLE", "Open a new shell in the root of the given castle"
|
||||||
|
def cd(castle = DEFAULT_CASTLE_NAME)
|
||||||
|
check_castle_existance castle, "cd"
|
||||||
|
castle_dir = repos_dir.join(castle)
|
||||||
|
say_status "cd #{castle_dir.realpath}", "Opening a new shell in castle '#{castle}'. To return to the original one exit from the new shell.", :green
|
||||||
|
inside castle_dir do
|
||||||
|
system(ENV['SHELL'])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
desc "open CASTLE", "Open your default editor in the root of the given castle"
|
||||||
|
def open(castle = DEFAULT_CASTLE_NAME)
|
||||||
|
if ! ENV['EDITOR']
|
||||||
|
say_status :error,"The $EDITOR environment variable must be set to use this command", :red
|
||||||
|
|
||||||
|
exit(1)
|
||||||
|
end
|
||||||
|
check_castle_existance castle, "open"
|
||||||
|
castle_dir = repos_dir.join(castle)
|
||||||
|
say_status "#{ENV['EDITOR']} #{castle_dir.realpath}", "Opening the root directory of castle '#{castle}' in editor '#{ENV['EDITOR']}'.", :green
|
||||||
|
inside castle_dir do
|
||||||
|
system(ENV['EDITOR'])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
@@ -278,10 +314,10 @@ class Homesick < Thor
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def commit_castle(castle)
|
def commit_castle(castle, message)
|
||||||
check_castle_existance(castle, 'commit')
|
check_castle_existance(castle, 'commit')
|
||||||
inside repos_dir.join(castle) do
|
inside repos_dir.join(castle) do
|
||||||
git_commit_all
|
git_commit_all :message => message
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
# -*- encoding : utf-8 -*-
|
||||||
class Homesick
|
class Homesick
|
||||||
module Actions
|
module Actions
|
||||||
# TODO move this to be more like thor's template, empty_directory, etc
|
# TODO move this to be more like thor's template, empty_directory, etc
|
||||||
@@ -10,7 +11,7 @@ class Homesick
|
|||||||
|
|
||||||
if ! destination.directory?
|
if ! destination.directory?
|
||||||
say_status 'git clone', "#{repo} to #{destination.expand_path}", :green unless options[:quiet]
|
say_status 'git clone', "#{repo} to #{destination.expand_path}", :green unless options[:quiet]
|
||||||
system "git clone -q --recursive #{repo} #{destination}" unless options[:pretend]
|
system "git clone -q --config push.default=upstream --recursive #{repo} #{destination}" unless options[:pretend]
|
||||||
else
|
else
|
||||||
say_status :exist, destination.expand_path, :blue unless options[:quiet]
|
say_status :exist, destination.expand_path, :blue unless options[:quiet]
|
||||||
end
|
end
|
||||||
@@ -63,8 +64,12 @@ class Homesick
|
|||||||
|
|
||||||
def git_commit_all(config = {})
|
def git_commit_all(config = {})
|
||||||
say_status 'git commit all', '', :green unless options[:quiet]
|
say_status 'git commit all', '', :green unless options[:quiet]
|
||||||
|
if config[:message]
|
||||||
|
system "git commit -a -m '#{config[:message]}'" unless options[:pretend]
|
||||||
|
else
|
||||||
system 'git commit -v -a' unless options[:pretend]
|
system 'git commit -v -a' unless options[:pretend]
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def git_add(file, config = {})
|
def git_add(file, config = {})
|
||||||
say_status 'git add file', '', :green unless options[:quiet]
|
say_status 'git add file', '', :green unless options[:quiet]
|
||||||
@@ -108,6 +113,37 @@ class Homesick
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def rm(file)
|
||||||
|
say_status "rm #{file}", '', :green unless options[:quiet]
|
||||||
|
system "rm #{file}" if File.exists?(file)
|
||||||
|
end
|
||||||
|
|
||||||
|
def rm_rf(dir)
|
||||||
|
say_status "rm -rf #{dir}", '', :green unless options[:quiet]
|
||||||
|
system "rm -rf #{dir}"
|
||||||
|
end
|
||||||
|
|
||||||
|
def rm_link(target)
|
||||||
|
target = Pathname.new(target)
|
||||||
|
|
||||||
|
if target.symlink?
|
||||||
|
say_status :unlink, "#{target.expand_path}", :green unless options[:quiet]
|
||||||
|
FileUtils.rm_rf target
|
||||||
|
else
|
||||||
|
say_status :conflict, "#{target} is not a symlink", :red unless options[:quiet]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def rm(file)
|
||||||
|
say_status "rm #{file}", '', :green unless options[:quiet]
|
||||||
|
system "rm #{file}"
|
||||||
|
end
|
||||||
|
|
||||||
|
def rm_r(dir)
|
||||||
|
say_status "rm -r #{dir}", '', :green unless options[:quiet]
|
||||||
|
system "rm -r #{dir}"
|
||||||
|
end
|
||||||
|
|
||||||
def ln_s(source, destination, config = {})
|
def ln_s(source, destination, config = {})
|
||||||
source = Pathname.new(source)
|
source = Pathname.new(source)
|
||||||
destination = Pathname.new(destination)
|
destination = Pathname.new(destination)
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
|
# -*- encoding : utf-8 -*-
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
require 'capture-output'
|
||||||
|
|
||||||
describe 'homesick' do
|
describe 'homesick' do
|
||||||
let(:home) { create_construct }
|
let(:home) { create_construct }
|
||||||
@@ -94,7 +96,7 @@ describe 'homesick' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should clone a github repo' do
|
it 'should clone a github repo' do
|
||||||
homesick.should_receive(:git_clone).with('https://github.com/wfarr/dotfiles.git', :destination => Pathname.new('wfarr/dotfiles'))
|
homesick.should_receive(:git_clone).with('https://github.com/wfarr/dotfiles.git', :destination => Pathname.new('dotfiles'))
|
||||||
|
|
||||||
homesick.clone 'wfarr/dotfiles'
|
homesick.clone 'wfarr/dotfiles'
|
||||||
end
|
end
|
||||||
@@ -340,9 +342,19 @@ describe 'homesick' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
describe 'status' do
|
describe 'status' do
|
||||||
|
it 'should say "nothing to commit" when there are no changes' do
|
||||||
|
given_castle('castle_repo')
|
||||||
|
text = Capture.stdout { homesick.status('castle_repo') }
|
||||||
|
text.should =~ /nothing to commit \(create\/copy files and use "git add" to track\)$/
|
||||||
|
end
|
||||||
|
|
||||||
xit 'needs testing'
|
it 'should say "Changes to be committed" when there are changes' do
|
||||||
|
given_castle('castle_repo')
|
||||||
|
some_rc_file = home.file '.some_rc_file'
|
||||||
|
homesick.track(some_rc_file.to_s, 'castle_repo')
|
||||||
|
text = Capture.stdout { homesick.status('castle_repo') }
|
||||||
|
text.should =~ /Changes to be committed:.*new file:\s*home\/.some_rc_file/m
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'diff' do
|
describe 'diff' do
|
||||||
@@ -371,12 +383,6 @@ describe 'homesick' do
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'commit' do
|
|
||||||
|
|
||||||
xit 'needs testing'
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'push' do
|
describe 'push' do
|
||||||
|
|
||||||
xit 'needs testing'
|
xit 'needs testing'
|
||||||
@@ -447,6 +453,16 @@ describe 'homesick' do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe 'commit' do
|
||||||
|
it 'should have a commit message when the commit succeeds' do
|
||||||
|
given_castle('castle_repo')
|
||||||
|
some_rc_file = home.file '.a_random_rc_file'
|
||||||
|
homesick.track(some_rc_file.to_s, 'castle_repo')
|
||||||
|
text = Capture.stdout { homesick.commit('castle_repo', 'Test message') }
|
||||||
|
text.should =~ /^\[master \(root-commit\) \w+\] Test message/
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe 'subdir_file' do
|
describe 'subdir_file' do
|
||||||
|
|
||||||
it 'should add the nested files parent to the subdir_file' do
|
it 'should add the nested files parent to the subdir_file' do
|
||||||
@@ -490,4 +506,63 @@ describe 'homesick' do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "destroy" do
|
||||||
|
it "removes the symlink files" do
|
||||||
|
expect_any_instance_of(Thor::Shell::Basic).to receive(:yes?).and_return('y')
|
||||||
|
given_castle("stronghold")
|
||||||
|
some_rc_file = home.file '.some_rc_file'
|
||||||
|
homesick.track(some_rc_file.to_s, "stronghold")
|
||||||
|
homesick.destroy('stronghold')
|
||||||
|
|
||||||
|
some_rc_file.should_not be_exist
|
||||||
|
end
|
||||||
|
|
||||||
|
it "deletes the cloned repository" do
|
||||||
|
expect_any_instance_of(Thor::Shell::Basic).to receive(:yes?).and_return('y')
|
||||||
|
castle = given_castle("stronghold")
|
||||||
|
some_rc_file = home.file '.some_rc_file'
|
||||||
|
homesick.track(some_rc_file.to_s, "stronghold")
|
||||||
|
homesick.destroy('stronghold')
|
||||||
|
|
||||||
|
castle.should_not be_exist
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "cd" do
|
||||||
|
it "cd's to the root directory of the given castle" do
|
||||||
|
given_castle('castle_repo')
|
||||||
|
homesick.should_receive("inside").once.with(kind_of(Pathname)).and_yield
|
||||||
|
homesick.should_receive("system").once.with(ENV["SHELL"])
|
||||||
|
Capture.stdout { homesick.cd 'castle_repo' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it "returns an error message when the given castle does not exist" do
|
||||||
|
homesick.should_receive("say_status").once.with(:error, /Could not cd castle_repo, expected \/tmp\/construct_container.* exist and contain dotfiles/, :red)
|
||||||
|
expect { homesick.cd "castle_repo" }.to raise_error(SystemExit)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "open" do
|
||||||
|
it "opens the system default editor in the root of the given castle" do
|
||||||
|
ENV.stub(:[]).and_call_original # Make sure calls to ENV use default values for most things...
|
||||||
|
ENV.stub(:[]).with('EDITOR').and_return('vim') # Set a default value for 'EDITOR' just in case none is set
|
||||||
|
given_castle 'castle_repo'
|
||||||
|
homesick.should_receive("inside").once.with(kind_of(Pathname)).and_yield
|
||||||
|
homesick.should_receive("system").once.with('vim')
|
||||||
|
Capture.stdout { homesick.open 'castle_repo' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it "returns an error message when the $EDITOR environment variable is not set" do
|
||||||
|
ENV.stub(:[]).with('EDITOR').and_return(nil) # Set the default editor to make sure it fails.
|
||||||
|
homesick.should_receive("say_status").once.with(:error,"The $EDITOR environment variable must be set to use this command", :red)
|
||||||
|
expect { homesick.open "castle_repo" }.to raise_error(SystemExit)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "returns an error message when the given castle does not exist" do
|
||||||
|
ENV.stub(:[]).with('EDITOR').and_return('vim') # Set a default just in case none is set
|
||||||
|
homesick.should_receive("say_status").once.with(:error, /Could not open castle_repo, expected \/tmp\/construct_container.* exist and contain dotfiles/, :red)
|
||||||
|
expect { homesick.open "castle_repo" }.to raise_error(SystemExit)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ require 'homesick'
|
|||||||
require 'rspec'
|
require 'rspec'
|
||||||
require 'rspec/autorun'
|
require 'rspec/autorun'
|
||||||
require 'construct'
|
require 'construct'
|
||||||
|
require 'tempfile'
|
||||||
|
|
||||||
RSpec.configure do |config|
|
RSpec.configure do |config|
|
||||||
config.include Construct::Helpers
|
config.include Construct::Helpers
|
||||||
@@ -21,6 +22,8 @@ RSpec.configure do |config|
|
|||||||
castles.directory(path) do |castle|
|
castles.directory(path) do |castle|
|
||||||
Dir.chdir(castle) do
|
Dir.chdir(castle) do
|
||||||
system 'git init >/dev/null 2>&1'
|
system 'git init >/dev/null 2>&1'
|
||||||
|
system 'git config user.email "test@test.com"'
|
||||||
|
system 'git config user.name "Test Name"'
|
||||||
system "git remote add origin git://github.com/technicalpickles/#{name}.git >/dev/null 2>&1"
|
system "git remote add origin git://github.com/technicalpickles/#{name}.git >/dev/null 2>&1"
|
||||||
if subdirs
|
if subdirs
|
||||||
subdir_file = castle.join(Homesick::SUBDIR_FILENAME)
|
subdir_file = castle.join(Homesick::SUBDIR_FILENAME)
|
||||||
|
|||||||
Reference in New Issue
Block a user