寫一個測試工具類,只在debug時運行,而release時自動移除代碼,適用於gradle項目(idea,android studio等)

前言

平時開發有很多測試期間需要寫的代碼(比如日誌),如何不讓其在正式環境下運行呢?或者不讓其在正式環境下存在(防止反編譯查到重要信息)

實現方法

1.通過混淆

工具類示例: 這是一個打印當前堆棧信息的方法,可以用來跟蹤調用棧,測試環境下運行沒有問題,但是到正式環境下,會不斷的創建String對象,並且調用打印方法消耗資源

object TestUtil {

    /**
     * 打印當前堆棧的調用信息
     */
    fun printAllStackInfo() {
        Log.e("printAllStackInfo","**********************************start")
        Thread.getAllStackTraces()[Thread.currentThread()]?.forEach {
            Log.e("printAllStackInfo",it.toString())
        }
        Log.e("printAllStackInfo","**********************************end")
    }
}

通過配置混淆文件如下: 就可以在正式版中移除該方法

-assumenosideeffects class com.lt.androidkj.utils.TestUtil { # todo 改成自己的包名
public *** printAllStackInfo(...);
}

app.gradle中配置如下:

buildTypes {
        release {
            minifyEnabled true //混淆
            shrinkResources true//混淆壓縮代碼
            proguardFiles /*getDefaultProguardFile('proguard-android.txt'),參考 https://www.ctolib.com/topics-116127.html*/ 'proguard-rules.pro'
        }
    }

2.通過系統配置

這種方式比較簡單,可以改造上面的工具類,如下所示:

object TestUtil {

    /**
     * 打印當前堆棧的調用信息
     */
    fun printAllStackInfo() {
        if(!BuildConfig.DEBUG)//加了這個判斷
            return
        Log.e("printAllStackInfo","**********************************start")
        Thread.getAllStackTraces()[Thread.currentThread()]?.forEach {
            Log.e("printAllStackInfo",it.toString())
        }
        Log.e("printAllStackInfo","**********************************end")
    }
}

通過BuildConfig.DEBUG可以判斷當前環境是否是測試環境

該方式比較簡單,但是反編譯後有機率可以被看到源碼(BuildConfig.DEBUG後面的代碼可能會被編譯器優化掉),並且調用棧不會被移除

3.通過自定義配置gradle

第三種方式參考:https://blog.csdn.net/hp910315/article/details/52488474

結語

該篇博客並沒有提供工具類,而是提供了一種思路,可以自己封裝一些工具類,並且開發更方便

比如日誌系統,測試代碼執行時間,打印堆棧,測試的toast等,如果有什麼好的想法可以留言,讓我也用上 \滑稽

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章