From 070381bb456b25f3e867e9b23b78911190c6b369 Mon Sep 17 00:00:00 2001 From: scott Chacon Date: Sun, 11 Nov 2007 11:32:57 -0800 Subject: added remove and reset --- tests/units/test_index_ops.rb | 106 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 tests/units/test_index_ops.rb (limited to 'tests/units') diff --git a/tests/units/test_index_ops.rb b/tests/units/test_index_ops.rb new file mode 100644 index 0000000..b3946b8 --- /dev/null +++ b/tests/units/test_index_ops.rb @@ -0,0 +1,106 @@ +#!/usr/bin/env ruby + +require File.dirname(__FILE__) + '/../test_helper' + +class TestIndexOps < Test::Unit::TestCase + + def setup + set_file_paths + @git = Git.open(@wdir) + end + + def test_add + in_temp_dir(false) do |path| + g = Git.clone(@wbare, 'new') + Dir.chdir('new') do + assert_equal('100644', g.status['example.txt'].mode_index) + + new_file('test-file', 'blahblahblah') + assert(g.status.untracked.assoc('test-file')) + + g.add + assert(g.status.added.assoc('test-file')) + assert(!g.status.untracked.assoc('test-file')) + assert(!g.status.changed.assoc('example.txt')) + + append_file('example.txt', 'hahahaha') + assert(g.status.changed.assoc('example.txt')) + + g.add + assert(g.status.changed.assoc('example.txt')) + + g.commit('my message') + assert(!g.status.changed.assoc('example.txt')) + assert(!g.status.added.assoc('test-file')) + assert(!g.status.untracked.assoc('test-file')) + assert_equal('hahahaha', g.status['example.txt'].blob.contents) + end + end + end + + def test_add_array + in_temp_dir do |path| + g = Git.clone(@wbare, 'new') + Dir.chdir('new') do + + new_file('test-file1', 'blahblahblah1') + new_file('test-file2', 'blahblahblah2') + assert(g.status.untracked.assoc('test-file1')) + + g.add(['test-file1', 'test-file2']) + assert(g.status.added.assoc('test-file1')) + assert(g.status.added.assoc('test-file1')) + assert(!g.status.untracked.assoc('test-file1')) + + g.commit('my message') + assert(!g.status.added.assoc('test-file1')) + assert(!g.status.untracked.assoc('test-file1')) + assert_equal('blahblahblah1', g.status['test-file1'].blob.contents) + end + end + end + + def test_remove + in_temp_dir do |path| + g = Git.clone(@wbare, 'remove_test') + Dir.chdir('remove_test') do + assert(g.status['example.txt']) + g.remove('example.txt') + assert(g.status.deleted.assoc('example.txt')) + g.commit('deleted file') + assert(!g.status['example.txt']) + end + end + end + + def test_reset + in_temp_dir do |path| + g = Git.clone(@wbare, 'reset_test') + Dir.chdir('reset_test') do + new_file('test-file1', 'blahblahblah1') + new_file('test-file2', 'blahblahblah2') + assert(g.status.untracked.assoc('test-file1')) + + g.add(['test-file1', 'test-file2']) + assert(!g.status.untracked.assoc('test-file1')) + + g.reset + assert(g.status.untracked.assoc('test-file1')) + assert(!g.status.added.assoc('test-file1')) + end + end + end + + def new_file(name, contents) + File.open(name, 'w') do |f| + f.puts contents + end + end + + def append_file(name, contents) + File.open(name, 'a') do |f| + f.puts contents + end + end + +end \ No newline at end of file -- cgit