成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

每個Java開發者應該知道的八個工具

開發 后端
使用正確的工具不僅僅幫助你節省時間提高效率,還能提高你作品的質量并享受日常工作。我們要時刻留心,發現并學習新的工具。一開始可能需要一些努力,但你總會意識到付出的時間是值得的。

在Stormpath(一款用戶管理和認證服務),我們認真對待質量和效率。任何一個優秀的工匠,僅僅擁有天賦是不夠的,你在工作中還需要正確的工具。工程學不僅僅是科學,更是藝術。所以,在Stormpath,盡管我們擁有天賦,我們仍不斷尋找所需的有用的工具。我們的工程師一直渴望向團隊其他人分享新工具。現在,讓我們向所有充滿天賦的Java開發者推薦工具。

在這篇文章中,我將分享我們Java團隊日常工作使用的工具,并介紹如何使用它們,分享一些實用的小技巧。

[[179739]]

1.Groovy

我們使用Groovy來寫Java測試。為什么?因為它提供了下面這些能力:

寬松的Java語法:這是Java語法,但有些其他規則,比如分號,變量類型,訪問修飾符都是可選的。后者對于測試意義重大,由于訪問修飾符不是嚴格的,你的測試可以讀取并斷言類內部的狀態。舉個例子,我們假設下面一個類:

  1. public class Foo { 
  2.     private String bar = null
  3.  
  4.     public void setBar(String bar) { 
  5.         this.bar = bar; 
  6.     } 

如果你想測試setBar(String)方法正常(即能正確修改bar的值),你可以用Groovy方便的讀取變量值。Java中不允許這樣的操作(在不涉及Java反射機制前提下)。

 

  1. @Test public void test() { 
  2.     def foo = new Foo() 
  3.     foo.setBar("hello"
  4.     Assert.isTrue(foo.bar.equals("hello")) 
  5.     //groovy 允許我們訪問私有變量 bar 

強大的斷言:Groovy提供強大多樣的assert,被稱作power assertion statement。Groovy的強大斷言能夠清晰的展示驗證失敗時的結果。另外,它比Java更有可讀性。

  1. Assert.isTrue(foo.bar.equals("hello")); 

可以用Groovy這樣寫:

  1. assert foo.bar == "hello" 

當斷言失敗時它會顯示一個非常清晰的描述:

 

  1. assert foo.bar == "goodbye" 
  2.        |   |   | 
  3.        |   |   false 
  4.        |   hello 
  5.        Foo@12f41634 

Mocking:使用Java時,動態模擬框架(如:EasyMock,PowerMock和Mockito)非常流行,這些框架可以在Groovy下方便的使用。耶!

2.支持REST風格

我們的后端提供REST API服務來創建和管理賬戶,眾多SDK中,我們的Java SDK提供特定語言客戶端模型做簡單交互。其中一些SDK也提供網頁來和后端交互,從而不用編寫代碼。

為了保證網絡框架的互操作性,它們必須表現的一樣。因此我們需要創建一系列基于HTTP的測試。這是我們的兼容性測試工具。這個項目由我們的SDK工程師維護,他們精通不止一種語言。因此我們需要跨語言測試工具,謝天謝地Rest-assured來了。

Rest-assured是Java領域特定語言(DSL domain-specific language)用來測試REST服務,它簡單易用易上手,甚至對于沒有用過Java的開發者也是難以置信的強大。它提供先進的特性,比如細節配置、過濾器、定制分析、跨站請求偽造(CSRF)和OAuth 2.0。它提供非常簡單的語法:given-when-then。

舉個例子:讓我們來看它如何校驗“向/login路徑發送post認證信息請求返回302狀態碼”:

given() .accept(ContentType.HTML) .formParam("login", account.username) .formParam("password", account.password) .when() .post(LoginRoute) .then() .statusCode(302)

你可以在我們的TCK repo中看到更多Rest-assured測試

3.Cargo Plugin

為了讓我們的Java SDK按照TCK校驗,我們需要開啟我們其中一個Web服務,以便測試在上面執行。講道理的話,我們需要每次構建時自動測試,Gargo Plugin就是為此而生。

Cargo用標準的方式簡單封裝各種應用容器。我們使用Cargo可以毫不費力的在不同的Servlet容器(比如Jetty和Tomcat)中運行我們的代碼。我們只需要在我們的pom文件中配置Cargo Maven2 Plugin來啟動一個Servlet容器(Tomcat7),在測試階段編譯最近的War包,你可以在我們的Servlet插件例子中看到配置。

4.Git

我們能討論哪些關于Git你不了解的事情呢?想要深入了解Git,你可以看他們的About頁。

我們的Java SDK團隊遍布全球,而且彼此之間幾乎從未坐在一起。Git保障了我們寫的每一行代碼,這里有一些非常棒的命令,節省了我們大量的時間:

  • git mv –force foo.java Foo.java:在大小寫敏感的文件系統中改變文件名是非常麻煩的,這個命令能讓git意識到foo.java重命名為Foo.java

  • git diff-tree –no-commit-id –name-only -r <commit_ID>:查看所有在<commit_ID>這次提交中更改的文件。

  • git diff –name-only SHA1 SHA2:列舉出在SHA1和SHA2兩次提交之間所有更改的文件。

  • 在一個文件的歷史提交記錄中查詢某個字符串:創建search.sh文件,粘貼下面代碼:

  1. git rev-list --all $2 | ( 
  2.     while read revision; do 
  3.         git grep -F $1 $revision $2 
  4.     done 

命令可以通過這種方式執行:sh ./search.sh string_to_search file_where_to_search

5.GitHub

GitHub不僅僅為我們的Git項目提供托管服務,它為代碼開源并讓全世界都看到做出了巨大貢獻。這鼓舞了人們去嘗試、去交流、去練習,很大程度提高了每個人的項目質量和大家的技術水平。

GitHub允許我們跟進我們的issue.游客可以提交新需求和報告bug。他們也可以收到我們項目進展的通知。

6.Maven

Maven已經足夠出名了。所以我不會用長篇幅解釋為什么我們使用Maven做構建管理。然而我可以分享幾個技巧,讓你的Maven更得心應手:

管理依賴:在一個多模塊的項目中,你需要在根pom.xml的<dependencyManagement>標簽中定義每一個依賴。一旦你這樣做,所有下層模塊都可以不需要指定版本。這種管理依賴的方式(比如版本升級)可以集中處理,所有下層模塊都會自動識別。比如在根pom.xml:

  1. <dependencyManagement> 
  2.   <dependencies> 
  3.     <dependency> 
  4.         <groupId>io.jsonwebtoken</groupId> 
  5.         <artifactId>jjwt</artifactId> 
  6.         <version>${jjwt.version}</version> 
  7.      </dependency> 
  8.      ... 
  9.   <dependencies> 
  10. <dependencyManagement> 

下層模塊的pom.xml:

  1. <dependencies> 
  2.   <dependency> 
  3.       <groupId>io.jsonwebtoken</groupId> 
  4.       <artifactId>jjwt</artifactId>  <!-- 注意這里沒有指定版本 --> 
  5.   </dependency> 
  6.   ... 
  7. <dependencies> 

阻止下層模塊編譯:在發布的時候我們需要所有下層模塊一起發布,但是我們如何避免某個模塊(比如example)發布呢?很簡單,只需要把下面的pom文件加入到你不想發布的模塊:

  1. <plugin> 
  2.     <groupId>org.apache.maven.plugins</groupId> 
  3.     <artifactId>maven-deploy-plugin</artifactId> 
  4.     <version>2.7</version> 
  5.     <configuration> 
  6.         <skip>true</skip>  <!-- (敲黑板)這是重點 --> 
  7.     </configuration> 
  8. </plugin> 

跳過集成測試:我們有很多集成測試需要很長時間編譯。這些測試確保了后端整體運行正常.在頻繁的本地部署期間,我們多次因為新功能或修復bug而更改代碼。并不需要每次在本地構建的時候執行這些測試,這會拖慢開發進度。因此我們要確保我們的Java SDK只在我們的CI服務器上運行的時候執行集成測試。可以通過下面方法:

根pom.xml文件:

  1. <properties> 
  2.     <skipITs>true</skipITs> 
  3. </properties> 
  4. ... 
  5. <build> 
  6.     <plugins> 
  7.         <plugin> 
  8.             <groupId>org.apache.maven.plugins</groupId> 
  9.             <artifactId>maven-failsafe-plugin</artifactId> 
  10.             <version>2.19.1</version> 
  11.             <configuration> 
  12.                 <skipITs>${skipITs}</skipITs> 
  13.                 <includes> 
  14.                     <include>**/*IT.*</include> 
  15.                 </includes> 
  16.             </configuration> 
  17.             <executions> 
  18.                <execution> 
  19.                    <goals> 
  20.                        <goal>integration-test</goal> 
  21.                        <goal>verify</goal> 
  22.                    </goals> 
  23.                </execution> 
  24.             </executions> 
  25.         </plugin> 
  26.   </plugins> 
  27. <build> 

所以你可以想象到,所有集成測試文件以IT結尾,來保證配置正常運作,比如:ApplicationIT.groovy 或 I18nIT.groovy

然后,如果我們想讓集成測試運行,我們執行以下構建:mvn clean install -DskipITs=false

7.JWT Inspector

我們的Java SDK使用JWT(JSON Web Token)通過安全可靠的方式傳輸數據。當我們測試排查時,我們需要分析從瀏覽器接收到的JWT內容。token信息可能在URL,cookie或本地儲存中。JWT Inspector是一款瀏覽器插件,讓我們可以從控制臺或內置的界面解碼JSON Web Token。你不需要在你的app中跟蹤token信息。你只需要按一下插件的按鈕,JWT Inspector會自動展示你所需要的所有信息,然后你可以復制其中任何token信息。

8.Postman

我們重度依賴REST API請求,編寫REST請求并不方便,具體語法取決于我們所用的工具,比如curl或HTTPie。兩者都易讀,但語法難記。通常,我們需要排查問題時,我們需要測試一些請求。當出問題時,我們無法判斷原因是請求還是后端。我們浪費了大量時間來懷疑我們寫的請求是否正確。

Postman讓書寫REST API請求變得簡單。它也提供很多功能,比如保存、復用請求、生成代碼(java,python,curl等等),還可以批量按序執行請求。Postman通過友好的界面幫助你構建復雜的命令,你所需要做的就是填寫一個表單,簡直不能再棒了。

總結

使用正確的工具不僅僅幫助你節省時間提高效率,還能提高你作品的質量并享受日常工作。我們要時刻留心,發現并學習新的工具。一開始可能需要一些努力,但你總會意識到付出的時間是值得的。

譯文鏈接:http://www.codeceo.com/article/8-tools-every-java-developer-love.html
英文原文:Eight Tools Every Java Developer Should Know (and Love)

 

責任編輯:張燕妮 來源: 碼農網
相關推薦

2025-03-05 09:21:08

2017-04-12 09:42:29

Java開發工具

2019-11-20 12:09:01

JavaScriptGitHub工具

2023-11-27 15:49:55

軟件開發系統設計

2023-11-17 14:18:48

開發編程

2016-03-04 10:18:24

xcode技巧開發

2016-03-04 10:25:50

Xcode技巧開發

2022-04-27 09:48:56

JS前端開發

2024-01-26 06:25:09

PyCharm插件代碼

2012-11-13 10:34:03

PythonWeb

2023-12-01 15:38:22

IT領導者數字化轉型

2019-11-23 23:38:51

開發者微服務安全

2013-06-26 09:42:52

Web開發URL編碼URL

2022-05-26 07:31:42

索引SQL后端

2023-08-11 18:11:49

2021-03-09 10:26:24

Python開發工具

2018-10-16 11:03:19

API開發者AR

2011-10-11 10:07:37

2016-12-19 15:35:10

Web開發者jQueryi18n

2023-08-10 08:31:53

工具實用網站
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品99久久免费观看 | 精品国产黄a∨片高清在线 成人区精品一区二区婷婷 日本一区二区视频 | 综合久久av | 国产精品国产成人国产三级 | 欧美电影免费观看 | 黄色片在线网站 | 日韩一区三区 | 天天干,夜夜操 | 一级片在线观看 | 国产精品成人一区 | 91国在线高清视频 | 九九亚洲 | 亚洲日本乱码在线观看 | 区一区二在线观看 | 日韩有码一区 | 一级毛片在线播放 | 国产视频一区二区 | 日韩视频一区 | 国产成人精品久久二区二区91 | 激情av| 一区二区电影网 | 久久久久久久久国产成人免费 | 狠狠爱一区二区三区 | 自拍偷拍亚洲欧美 | 日本精品一区二区三区在线观看视频 | 91看片官网 | 日本天天色 | 久久久久久久久久久91 | 国产精品一级 | 国产精品日韩一区二区 | 99精品免费 | 精品国产乱码久久久久久丨区2区 | 毛片一级网站 | 欧美精品福利视频 | 欧美一级片在线观看 | 久久69精品久久久久久久电影好 | 久久这里有精品 | 91麻豆精品国产91久久久久久 | 99久久久久国产精品免费 | 久久久久久久一区二区三区 | 色婷婷影院 |