美團外賣服務端的測試面試題居然洩。。洩。。洩。。洩密了。

testingbang發表於2019-08-12

1. 列出你常用的 linux 命令

答: vim/touch/cat/tail/grep/cd/chmod/mv/rm

2. 測試介面時,常會遇到需要傳入不同引數來測試不同場景,如何實現

答:自己寫方法,並新增到 test 中去。詳細程式碼後期補充。

3. 瀏覽器中輸入一個 URL 後,詳細說明將會發生什麼

答: 1. 解析 URL

2. 透過 DNS 找到域名對應的伺服器 IP

3. 瀏覽器與服務端進行 TCP 三次握手  

   第一次握手:客戶端向伺服器端傳送請求;

   第二次握手:伺服器收到請求並確認;

   第三次握手:客戶端收到伺服器的回覆指令並返回確認

4. 請求和傳輸資料

5. 瀏覽器渲染頁面

4. 如何檢視 linux 系統程式

答: ps -aux  ps -aux | grep java

5. 如何檢視 linux 實時日誌檔案

答: tail -f 

6. 如何檢視 Linux CPU 資訊

答: cat /proc/cpuinfo

7. 程式和執行緒的區別

答: 1. 定義:

程式:程式有一定獨立功能的程式,是系統進行資源分配和除錯的一個獨立單位

執行緒:執行緒是程式的一個實體,它比程式更小的能獨立執行的基本單位

2. 關係:

同一個程式的多個執行緒之間可以併發執行;

相對程式而言,執行緒可以與同程式中的其他執行緒共享資料

3. 區別:

1 )一個程式至少有一個程式,一個程式至少有一個執行緒

2 )執行緒的劃分驚訝小於程式,使得多執行緒程式的併發性高

3 )程式在執行過程中擁有獨立的記憶體單元,而多個執行緒共享記憶體,從而提高執行效率

4 )每個程式有獨立的執行入口和出口,執行緒不能獨立執行

5 )多執行緒的意義在於一個應用程式中,有多個執行部分可以同時執行。

4. 優缺點

執行緒執行開銷小,但不利於資源的管理和保護

程式正相反

8. 給定一無序列表,如何去重,程式碼實現

答:

1) 解法一:

ids = [1,2,3,3,4,2,3,4,5,6,1]

new_ids = []

for id in ids:

  if id not in new_ids:

    news_ids.append(id)

 

p rint ( new_ids )

2) 解法二:

ids = [1,2,3,4,3,2,5]

new_ids = list(set(ids))

print(new_ids)

9. 程式碼寫說二分法查詢

答:時間複雜度:O(log2n);

def  Search(array,t):

    low = 0

    height = len(array)-1

     while  low < height:

        mid = (low+height)/2

         if  array[mid] < t:

            low = mid + 1

         elif  array[mid] > t:

            height = mid - 1

         else :

             return  array[mid]

     return  -1

if   __name__  ==  "__main__" :

    p rint( Search([1,5,6,8,10,15,18,25],5))

 

 

10. 給一個資料庫表,一個 Order 表,有商戶 id ,訂單 id,  商品數量,與商品單價,求某商戶的銷售額,寫 sql

答:

id

Order_id

num

price

10001

9000001

3

100

10001

9000002

2

50

10002

9000003

1

1000

SELECT id, (num * price) as sum_price FROM Order ORDER BY id

11. 介面測試時主要關注什麼

答:狀態碼與訊息值

12. HTTP 錯誤中 503 代表什麼意思

答: 5XX 為伺服器返回的錯誤,其中 503 代表了服務不可用是的一種狀態,可能是伺服器正在維護或者暫停了,或是 CPU 佔用的頻率大導致的。

13. selenium 中如何定位動態 元素

答: 1) xpath 2) 動態元素的規律  3) 找到父元素,透過 dom 結構定位

14. 求一有序列表 [1,2,3,4,4,4,5,6] 4 的區間,程式碼實現

答:

def get_all_index(self, arr, target):

return [i for i, a in enumerate(arr) if a == target]

If __name__ == “__main__”:

arr =  [1,2,3,4,4,4,5,6]

target = 4

s = get_all_index(arr, target)

print(s[0], s[-1])

15. 用程式碼判斷一個 IP 是否正確

答:

1) 解法一

try:

first = int(input(“ 請輸入第一個 1-255 數字: ”))

second = int(input(“ 請輸入第二個 0-255 的數字 :”))

third = int(input(“ 請輸入第三個 0-255 的數字: ”))

fourth = int(input(“ 請輸入第四個 0-255 的數字: ”))

except Exception as e:

print(“ 請輸入數字 ”)

if 1 <= first <= 255:

if 0<= second <= 255:

if 0<= third <= 255:

if 0 <= fourth <= 255:

print(“IP %s.%s.%s.%s 有效 ” % (first, second, third, fourth))

else:

print(“IP 無效 ”)

2) 解法二:

import re    

def judge_legal_ip(one_str):  

    ''''' 

    正則匹配 方法 

    判斷一個字串是否是合法 IP 地址 

    '''      

compile_ip=re.compile('^((25[0-5]|2[0-4]d|[01]?dd?).)’

’{3}(25[0-5]|2[0-4]d|[01]?dd?)$')    

    if compile_ip.match(one_str):    

        return True    

    else:    

        return False     

def judge_legal_ip2(one_str):  

    ''''' 

    簡單的字串判斷 

    '''  

    if '.' not in one_str:  

        return False  

    elif one_str.count('.')!=3:  

        return False  

    else:  

        flag=True  

        one_list=one_str.split('.')  

        for one in one_list:  

            try:  

                one_num=int(one)  

                if one_num>=0 and one_num<=255:  

                    pass  

                else:  

                    flag=False  

            except:  

                flag=False  

        return flag  

                      

if __name__=='__main__':  

ip_list=['','172.31.137.251','100.10.0.1000','1.1.1.1','12.23.13',

'aa.12.1.2','12345678','289043jdhjkbh']  

    for one_str in ip_list:  

        if judge_legal_ip(one_str):  # 正則方法  

        #if judge_legal_ip2(one_str):  # 字串方法  

            print ('{%s} is a legal ip address!' % (one_str))

        else:  

            print ('{%s} is not a legal ip address!' % (one_str))

 

16. 資料庫左連線和右連線有什麼區別,結果上有什麼不同。

答:左連線是以左表為基準,右連線是以右表為基準。結果看具體情況,相同的是不足的地方會顯示為 NULL

17. 給一個二叉樹,演算法實現樹的先序、中序後序

答:先序:根左右;中序:左根右;後序:左右根

// 輸出

void Visit(BiTree T){

    if(T->data != '#'){

        printf("%c ",T->data);

    }

}

// 先序遍歷

void PreOrder(BiTree T){

    if(T != NULL){

        // 訪問根節點

        Visit(T);

        // 訪問左子結點

        PreOrder(T->lchild);

        // 訪問右子結點

        PreOrder(T->rchild);

    }

}

// 中序遍歷

void InOrder(BiTree T){

    if(T != NULL){

        // 訪問左子結點

        InOrder(T->lchild);

        // 訪問根節點

        Visit(T);

        // 訪問右子結點

        InOrder(T->rchild);

    }

}

// 後序遍歷

void PostOrder(BiTree T){

    if(T != NULL){

        // 訪問左子結點

        PostOrder(T->lchild);

        // 訪問右子結點

        PostOrder(T->rchild);

        // 訪問根節點

        Visit(T);

    }

}

18. 說出 selenium 的原理

答:

1) selenium1.0 + webdriver = selenium2.0

2) selenium1.0 = selenium IDE + seleniumRC + selenium Grid

原理:

1) 啟動瀏覽器後, selenium-webdriver 會將目標瀏覽器繫結到特定的埠,啟動後的瀏覽器則作為 webdriver remote server

2) 客戶端 ( 也就是測試指令碼 ) ,藉助 ComandExecutor 傳送 HTTP 請求給 sever ( 指瀏覽器 )

3)Sever 端需要依賴原生的瀏覽器元件,轉化 Web Service 的命令為瀏覽器 native 的呼叫來完成操作。

 

19. 說說你平常工作流程?你認為哪裡有缺陷。

答:

20. 簡要說明你在過去的工作中的亮點

答:

21. 說說過去為什麼要跳槽

答:個人發展、公司前景或其他因素

22 . 有什麼要問我的

注:這裡一定要問,我之前在其他地方看到有同學是這樣問的 如果我有幸收到貴公司的 offer ,那麼有什麼知識或技能是要我在入職前一定了解或是掌握的? 或是 如果我有幸收到貴公司的 offer ,那麼我將會被分在哪個組,主要的工作內容是什麼?


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69942496/viewspace-2653348/,如需轉載,請註明出處,否則將追究法律責任。

相關文章