Skip to main content

(CI) Hướng dẫn thiết lập Jenkins cho dự án về iOS trên GitHub

Thiết lập Jenkins cho dự án về iOS trên GitHub

Jenkins là một server continuous integration, theo mã nguồn mở vì thế bạn có thể dễ dàng sử dụng và tuỳ chỉnh theo ý bạn. Trang chủ của Jenkins tại đây.
Sau đây là hướng dẫn của mình khi bạn cài đặt Jenkins cho dự án về iOS trên Yosemite.

Cách cài đặt Jenkins:

Bạn vào trang chủ của Jenkins và download gói jenkins theo từng môi trường và cài đặt chúng trên máy của bạn:


Sau khi cài đặt gói jenkins này thành công sẽ tự động chạy jenkins với địa chỉ http://localhost:8080/ bạn có thể thay đổi lại trong config.
Mỗi lần khởi động máy thì jenkins sẽ tự động chạy, nếu jenkins không tự động chạy bạn có thể khởi động jenkins trong thư mục /Applications/Jenkins, bằng cách dùng lệnh khởi động app bằng java -jar.

Mặc định gói jenkins này chỉ chạy trên Java 6, vì thế trên Yosemite dùng Java 8 nên các bạn phải sửa nội dung file "jenkins-runner.sh" trong thư mục "/Library/Application\ Support/Jenkins/" như sau:
- Thêm đoạn này vào:
 export JAVA_HOME="/Library/Internet Plug-Ins/JavaAppletPlugin.plugin/Contents/Home"  
- Thay 2 dòng cuối file bằng những dòng sau:
 echo "/Library/Internet Plug-Ins/JavaAppletPlugin.plugin/Contents/Home/bin/java" $javaArgs -jar "$war" $args
exec "/Library/Internet Plug-Ins/JavaAppletPlugin.plugin/Contents/Home/bin/java" $javaArgs -jar "$war" $args
Bạn có thể xem thêm tại đây.

Cách thiết lập thông tin user:

Sau khi cài xong jenkins thì hệ thống sẽ tự động thêm user jenkins vào vì thế bạn cần cài đặt user đó để có thể thiết lập và chạy dễ dàng.
Bạn mở System References -> Users & Groups. User jenkins có tên là rỗng, vì thế bạn chọn tên user với tên trống đó thay đổi password và avatar cho chúng dễ nhìn.

Sau đó bạn login vào hệ thống theo account jenkins.

- Bạn mở terminal lên và chạy những đoạn lệnh sau:
+ Thiết lập quyền Admin cho user Jenkins:
 sudo dseditgroup -o edit -a jenkins -t user admin

+ Thêm user Jenkins vào nhóm Developer:
 sudo dscl . append /Groups/_developer GroupMembership jenkins

+ Thiết lập tự động login vào user Jenkins (Optional):
 System Preferences > Users & Groups > Login Options > Automatic Login > set to Jenkins > restart CI machine // you should now be logged in as Jenkins

+ Di chuyển file "org.jenkins-ci.plist" từ thư mục"LaunchDaemon" qua thư mục "LaunchAgent" (Optional):
 sudo launchctl unload /Library/LaunchDaemons/org.jenkins-ci.plist
mv /Library/LaunchDaemons/org.jenkins-ci
.plist /Library/LaunchAgents/
 sudo launchctl load /Library/LaunchAgents/org.jenkins-ci.plist

+ Hiện tại những thiết lập như trên là bạn đang config cho user jenkins. Nếu bạn muốn thiết lập cho user hiện tại bạn đang sử dụng thì thực hiện sửa thông tin trong file "org.jenkins-ci.plist". Lệnh mở file thông qua lệnh sau (Optional):
sudo vim /Library/LaunchAgents/org.jenkins-ci.plist
Nội dung thay đổi như sau:
Sau khi sửa xong bạn lưu lại và dùng lệnh "sudo launchctl unload" và "sudo launchctl load" để load lại thông tin thiết lập mới. Sau đó khởi động lại jenkins.

Cách thiết lập thông số cho Jenkins:

Đầu tiên bạn cần phải cài những plugin cho Jenkins như Github pluginXCode plugin. Bạn chọn tab Manage Jenkins -> Manage Plugins:

Trong màn hình này bạn chon tab 'Avaiable' và ô Filter bạn nhập tên plugin bạn muốn cài đặt vào đó:

Sau khi cài đặt xong bạn nên khởi động lại jenkins và vào trong màn hình "Configure System" để kiểm tra xem XCode plugin có cài thành công hay chưa:
Nếu bạn thấy như hình trên tức là bạn đã cài thành công.

Những plugin hữu ích khi dùng jenkins:
- HTML Publisher plugin: Dùng để thiết lập đường dẫn đến file report của code coverage.
- Cocoapobs plugin: Dùng lệnh cocoapobs trên project.
- MobileCloudThe MobileCloud for Jenkins plugin enables  mobile apps to automatically upload from within the Jenkins build “job” to the MobileCloud Platform, where the app is installed on real mobile devices. It then launches a pre-defined Perfecto Mobile script and generates a detailed report, allowing developers to get early warnings of bugs and correct them prior to the QA stage. By using the MobileCloud Jenkins plugin, organizations can streamline the release cycle by delivering more mature and robust mobile apps to QA for a full mobile application test cycle (functional, performance, UI  testing).


Cách thiết lập dự án iOS trên Github với Jenkins:

Đầu tiên bạn phải có dự án đã được tải lên github. Mình đã có sẵn project, trong bài hướng dẫn code coverage mình viết để làm demo cho bài này. Vì thế mình có thể chạy luôn code coverage trên Jenkins.

Bạn vào màn hình trang chủ jenkins trên localhost, chọn 'New Item' sẽ ra màn hình như sau:
Tại đây bạn nhập tên dự án vào ô 'Item name' và chọp option 'Freestyle project', sau đó nhấn OK. Sau đó sẽ tự động vào màn hình configure để bạn thiết lập cho project này.

Bạn kéo xuống phần Source Code Management, bạn chọn theo Git. Ô Repository URL, bạn có thể nhập url source theo https hay ssh, ở đây mình dùng theo ssh. Sau đó nhấn vào nút Add để thêm key ssh vào đây (bạn có thể nhập theo username và password). Những thông số còn lại để theo mặc định:

Tiếp theo đó bạn kéo xuống phần Build. Nhấn Add build step -> Execute shell sẽ ra màn hình như sau:
Do trong project này mình có viết 1 đoạn script để build và chạy code coverage trong project do đó mình viết shell này để chạy file script đó như sau:
 cd DemoCodeCoverage
sh build.sh
open build/reports/coverage/index.html
Sau khi build và chạy code coverage xong mình sẽ tự động mở file html đó bằng câu lệnh shell là open.

Khi config xong hết, bạn nhấp ApplySave. Bạn sẽ ra màn hình của project đó bạn nhấn vào nút Build Now, để jenkins chạy project của bạn. Sau khi chạy xong thành công thì sẽ xuất hiện màn hình như sau:
Trong phần Build History thể hiện trạng thái của bản build này là thành công hay thất bại. Màu xanh dương là thành công, màu đỏ là thất bại. Nếu bạn build bị error hay bạn muốn xem jenkins chạy những gì thì bạn có thể vào trong Console để xem. Bạn nhấn vào từng bản build trong Build History -> Console Output
Bạn có thể thiết lập những tool để kiểm tra chất lượng code trên Jenkins tại đây.

Thế là mình đã config xong. Chúc các bạn thành công.

Công cụ dùng để viết: XCode 6.3, iOS 8.3

Những tài liệu hướng dẫn trên môi trường khác:


Tài liệu tham khảo:

- JENKINS OSX Installer
- JENKINS Starting and Accessing
- JenkinsCI-iOS
- ios-ci-jenkins
- Objective-C-CPD-Language

Comments

  1. Chào bạn, mình đang nghiên cứu về đề tài jenkins này.
    Mình đã làm theo các step trên hướng dẫn nhưng không hiểu sao lúc run lại failed hoặc bị đứng.
    không biết bạn có thể giúp mình được không? Cám ơn

    ReplyDelete

Post a Comment

Popular posts from this blog

Phân biệt biến kiểu Property, Public, Protected, Private trong ngôn ngữ Objective C

- Theo kinh nghiệm làm việc của mình với các bạn trong nhóm khi lập trình Objective-C và cũng đọc qua code của những project cũ. Ít khi nào mọi người để ý và khai báo đúng với ý đồ của từng đối tượng, và vi phạm quy tắc tính đóng gói, tính bảo mật thông tin của đối tượng trong lập trình hướng đối tượng (Tham khảo lý thuyết Lập trình hướng đối tượng tại trang Wiki ). - Theo ngôn ngữ lập trình Java, người ta khuyến khích mỗi khi dùng biến kiểu public thì nên đặt 1 biến private và hỗ trợ những hàm getter/setter để truy suất biến private đó.     + Nguyên nhân họ nói là đảm bảo tính đóng gói, và nếu sau này có thay đổi gì trên biến đó bạn có thể sửa được dễ dàng, chi tiết về vấn đề này ở đây .     + Nói tóm tại thì nguyên nhân chính là có thể kiểm soát được truy xuất đến giá trị của 1 đối tượng từ bên ngoài, có thể dễ dàng mở rộng code bằng cách override lại những hàm getter/setter. - Các bạn có thể áp dụng nguyên tắc đó từ bên Java qua ngôn ngữ lập trình Object...

(Kinh nghiệm) Auto layout và Size classes trong iOS - Phần 1

Trước đây khi viết những ứng dụng chạy trên nhiều màn hình hoặc hỗ trợ màn hình xoay ngang, xoay dọc mọi người hay dùng code để có thể chỉnh được những vị trí cũng như kích thước của những đối tượng. Hoặc có thể dùng Autosizing để tự động canh chỉnh những đối tượng nhưng không tối ưu và tiện lợi cho lắm, hình minh hoạ ở dưới: Vì thế từ lúc Apple phát hành ra iPhone 5, iPhone 5s với kích thước màn hình là 4 inch, làm phát sinh thêm vấn đề " Làm thế nào ta có thể thiết kế giao diện có thể chạy được trên nhiều màn hình? " mà không làm thay đổi nhiều code để có thể dễ dàng bảo trì ứng dụng. Apple mới phát triển chức năng Auto Layout và Size Classes để thực hiện nhiệm vụ này. Nếu bạn đã quen dùng Autosizing để thiết kế giao diện thì bạn có thể vẫn sử dụng chúng. Nhưng tuỳ theo từng dự án mà khách hàng hay người PM hoặc leader của bạn muốn bạn dùng công nghệ mới Auto Layout và Size Classes   để làm layout trên iOS mà không cần dùng bất cứ đoạn code nào và chỉ viết trên 1 storyboard...

(Căn bản) Bài 1: Hướng dẫn tạo tài khoản Apple ID và iTune không cần thẻ Visa hoặc MasterCard

Nếu bạn muốn lập trình trên iOs hoặc trên MacOs thì bạn nên có tài khoản Apple ID và tài khoản iTune. Sẽ hữa ích cho bạn khi cài đặt và nân cấp chương trình XCode. Nhưng khó khăn ở chỗ nếu bạn không có thẻ Visa hoặc Master Card, mà vẫn muốn có tài khoản để có thể cài ứng dụng trên AppStore. Sau đây mình xin hướng dẫn cách tạo tài khoản mà không cần những thẻ đó và có thể tạo tài khoản trên những store ở các nước khác. Đầu tiên bạn mở chương trình iTune lên và vào tab "App Store", sau đó bạn kiếm chương trình nào Free và nhấn vào đó nó sẽ hiển thị ra màn hình như sau:    Khi đang ở màn hình này bạn nhấn vào chữ "Free" bên dưới hình sẽ hiển thị ô cho bạn nhập Apple ID và Password.Vì bạn chưa có nên hãy nhấn vào nút "Create Apple ID" để tạo tài khoản. Sau khi bạn nhấn vào nút "Create Apple ID" bạn sẽ qua màn hình như bên dưới. Tại đây bạn có thể chuyển AppStore của các nước (Vì có những chương trình chỉ cài được trên từng AppStore mỗi nước thôi) hi...