Bài viết được sự cho phép của tác giả Tống Xuân Hoài
Vấn đề
Làm việc với git đã lâu nhưng có thể bạn chưa biết rằng trong git cũng có khái niệm hooks và họ gọi là githooks. Githooks được kích hoạt thông qua các sự kiện, từ đó giúp bạn có thể chèn thêm những công việc cần xử lý trước hoặc sau khi thực hiện hành động đó.
Githooks là gì?
Git cung cấp rất nhiều hooks, một số hooks phổ biến có thể kể đến là:
- pre-commit: Được gọi khi dùng lệnh
git commit
và nó được chạy trướcgit commit
- pre-receive: Đây là một hook được thực hiện ở phía server, được gọi trước khi
git push
. - post-commit: Được gọi sau khi dùng lệnh
git commit
. Hành vi trong post-commit không ảnh hưởng đến kết quả của commit vì nó được kích hoạt sau khi commit thành công. - post-receive: Đây là một hook được thực hiện ở phía server, được gọi sau khi dùng lệnh
git push
. Hành vi trong post-receive không ảnh hưởng đến kết quả của lệnh push vì nó được kích hoạt sau khi push thành công.
Để xem danh sách đầy đủ và mô tả của hooks bạn tham khảo thêm ở trang tài liệu git.
Mỗi kho lưu trữ Git đều có một thư mục .git/hooks
có chứa các file tương ứng cho mỗi hook mà bạn muốn sử dụng. Bạn có thể thay đổi nội dung các file này và Git sẽ thực thi chúng khi những sự kiện đó xảy ra.
Các hooks phía máy chủ được sử dụng để thực thi mạnh mẽ hơn các chính sách (policies) mà chúng ta muốn vì nó được được remote kiểm tra, bởi vì các hooks phía máy khách có thể dễ dàng bỏ qua bởi nhiều thủ thuật. Để biết những hook nào chạy ở phía máy khách hay chủ bạn có thể xem chi tiết trong tài liệu git.
Cách sử dụng Githooks
Khi dùng git init
để khởi tạo git repository cho project thì git cũng tạo những tệp example của các hook trong thư mục .git/hooks
các bạn có thể vào xem. Thực chất đây là những tập lệnh bash.
Ví dụ đây là nội dung của file pre-commit.sample
:
Đối với hooks pre-commit
, nếu bạn return một exit status khác 0 thì ngay lập tức commit sẽ bị huỷ bỏ và trả về lỗi. Để cấu hình sử dụng hook nào rất đơn giản chỉ cần đặt tên file là tên hooks trong thư mục .git/hooks
(xoá đuôi .sample
).
Tham khảo Job FrontEnd HOT trên TopDev!
Sử dụng pre-commit để ngăn chặn commit ẩu
Commit ẩu có thể là những commit chưa chịu chạy qua ESLint để kiểm tra cú pháp hay chưa chạy Unit test trước đó. Tuỳ vào trường hợp của bạn mà sẽ có những lúc bạn muốn ngăn chặn những commit mà vi phạm một lỗi nào đó được quy định từ trước. Những lúc như thế thì áp dụng hooks pre-commit
là quá chuẩn.
Ví dụ tôi muốn mỗi khi commit phải chạy qua Unit test, nếu thành công thì mới tiến hành commit còn không thì báo lỗi thì làm như sau.
Tạo file .git/hooks/pre-commit với nội dung:
#!/bin/sh
git stash -q --keep-index
npm run test
status=$?
git stash pop -q
exit $status
Trước khi run test
tôi tiến hành stash các file trước đó vì những file đó không nằm trong commit, rồi sau đó unstash và trả về exit với status là exit status của lệnh npm run test
. Cú pháp $?
trong bash là lấy exit code của task cuối cùng. Trong trường hợp sử dụng khác bạn có thể thay đổi npm run test
thành bất kì lệnh nào mà bạn muốn kiểm tra trước khi commit.
Tổng kết
Bên trên chỉ là một ví dụ nhỏ của việc sử dụng githook, ngoài pre-commit còn rất nhiều hook khác. Bằng cách kết hợp các hook sẽ giúp bạn giải quyết được điều vấn đề hơn nữa.
Bài viết gốc được đăng tải tại 2coffee.dev
Có thể bạn quan tâm: