[20171227] git difftool로 beyond comprare 사용하기
최근 git에 대해서 책을 보며 꼼꼼히 해보고 있다.
회사 업무에서는 사용이 불가능하기에 테스트 삼아 해보는데 꽤 재밋다.
diff의 모습을 보기가 쉽지 않았다.
difftool을 beyond compare로 지정하고 싶었다.
beyond compare는 무려 15년전 첫 직장에서 친구가 권해준 툴이었다.
지금도 매우 잘 사용하고 있는 툴이다. 다양한 파일을 지원하고 강력한 비교 기능을 제공한다.
기회가 되면 해보시라~
Windows용 git(msysgit) 의 diff 와 merge tool 로 Beyond Compare 3 사용하기
git merge vs git rebase...
특별한 일이 없는한 merge를 사용하는 것이 적절할 것이다.
다만 매우 큰 팀이나 복잡한 히스토리로 관리가 어려운 경우 rebase로 히스토리는 정리할 수 있을 것이다.
'프로그래밍??? > 매일코딩' 카테고리의 다른 글
[20170831] Golang 프로젝트에 TDD 도입하기 (0) | 2017.08.31 |
---|---|
[20170830] Go에서 테스트 작성하기 (0) | 2017.08.31 |
[매일] 시작 (0) | 2017.08.31 |
[20170831] Golang 프로젝트에 TDD 도입하기
Golang 프로젝트에 TDD 도입하기 - Golang Korean Community
위의 내용에 따라 간단한 테스트를 진행해 봤다.
이와 함께 assertion 패키지를 인스톨하고 사용했다.
if문으로 도배될 많은 테스트 코드들을 위해서 assertion은 필수라고 생각한다.
원래의 테스트 코드는 아래와 같이 if와 else로 구성할 수 밖에 없다.
func TestGetWords(t *testing.T) { if words, err := dbjobs.GetWords(); nil != err { t.Error("GetWords() return error. " + err.Error()) } else { tWord := []string{"a", "c", "d", "xxdfs", "ワード"} isSame := true for i, _ := range words { if words[i] != tWord[i] { isSame = false break } } if isSame { t.Logf("result is %v", words) } else { t.Errorf("Value is Not valid. \n first %v \n second %v", tWord, words) } } }
github.com/stretchr/testify 패키지를 인스톨하고 assert로 변경한 코드이다.
func TestGetWords(t *testing.T) { assert.Equal(t, 123, 125, "they should be equal") assert.NotEqual(t, 123, 456, "they should not be equal") words, err := dbjobs.GetWords() assert.Nil(t, err) t1Word := []string{"a", "c", "d", "xxdfs", "ワード"} assert.Equal(t, t1Word, words, "Words are not what I want.") t2Word := []string{"a", "b", "c", "d", "xxdfs", "ワード"} assert.Equal(t, t2Word, words, "Words are not what I want.") }
assertion 사용에 따른 결과는 아래와 같다.
Error Trace: job4mariadb_test.go:32 Error: Not equal: expected: 123 actual: 125 Messages: they should be equal Error Trace: job4mariadb_test.go:40 Error: Not equal: expected: []string{"a", "c", "d", "xxdfs", "ワード"} actual: []string{"a", "b", "c", "d", "xxdfs", "ワード"} Diff: --- Expected +++ Actual @@ -1,3 +1,4 @@ -([]string) (len=5) { +([]string) (len=6) { (string) (len=1) "a", + (string) (len=1) "b", (string) (len=1) "c", Messages: Words are not what I want.
-꼬리-
* 티스토리의 스타일 변경을 했다가 오랜 시간 기존 작성글들을 다시 수정해야 했다.
* 그 과정에서 오늘자로 작성한 내용이 날아갔다. ㅠ.ㅠ
* 그래서 간략히 다시 작성
'프로그래밍??? > 매일코딩' 카테고리의 다른 글
[20171227] git difftool로 beyond comprare 사용하기 (0) | 2017.12.27 |
---|---|
[20170830] Go에서 테스트 작성하기 (0) | 2017.08.31 |
[매일] 시작 (0) | 2017.08.31 |
[20170830] Go에서 테스트 작성하기
Go에서 테스트 작성하기 - 예제로 배우는 GO 프로그래밍
위의 내용을 참고하여 job4mariadb_test.go를 만들고 테스트를 하였다.
gogland에서 자동완성으로 테스트명과 테스트 함수를 편하게 생성할 수 있다.
또한 해당 파일만을 컴파일할때는 자동으로 go test를 실행해준다
package dbjobs_test import ( "testing" "asker/theWords/dbjobs" ) func TestGetWords(t *testing.T) { if words, err := dbjobs.GetWords(); nil != err { t.Error("GetWords() return error. " + err.Error()) } else { tWord := []string{"a", "b", "c", "d", "xxdfs", "ワード"} isSame := true for i := range words { if words[i] != tWord[i] { isSame = false break } } if isSame { t.Logf("result is %v", words) } else { t.Errorf("Value is Not valid. \n first %v \n second %v", tWord, words) } } }
'프로그래밍??? > 매일코딩' 카테고리의 다른 글
[20171227] git difftool로 beyond comprare 사용하기 (0) | 2017.12.27 |
---|---|
[20170831] Golang 프로젝트에 TDD 도입하기 (0) | 2017.08.31 |
[매일] 시작 (0) | 2017.08.31 |
[매일] 시작
주류에 속하지 못한 나같은 개발자의 삶은 희망하다 꺽이는 것이 일상이다.
비슷한 목표로 작업을 함께하고 코드에 대해 얘기해보고 싶다.
하는 일에 대한 조언을 주고 받거나 경쟁을 해보고 싶기도 하다.
가장 원하는 것은 팀으로 함께 일한 결과로 성과를 만들어내는 뿌듯함을 느껴보고 싶다.
현재에는 전혀 그렇게 하지 못하고 있다.
SW 개발은 내가 좋아했고 지금도 좋아하는 일이며 생계를 이어가는 도구이다.
초보 수준의 내용이라도 꾸준히 다시 짚는게 필요하다.
자주 쓰지 않으면 금방 잊혀진다.
일일단위의 기록을 작성해 보고자 한다.
'프로그래밍??? > 매일코딩' 카테고리의 다른 글
[20171227] git difftool로 beyond comprare 사용하기 (0) | 2017.12.27 |
---|---|
[20170831] Golang 프로젝트에 TDD 도입하기 (0) | 2017.08.31 |
[20170830] Go에서 테스트 작성하기 (0) | 2017.08.31 |