当前位置:网站首页>Basic knowledge of software testing, you can meet the interviewer after reading it
Basic knowledge of software testing, you can meet the interviewer after reading it
2022-04-23 01:44:00 【Sober Li Bai lisage】
This article takes a long time 3 Hours 、 I will explain my understanding of test knowledge , The writing idea is what I think and produce .
Additional benefits :
1、 A friend needs to test the resume template ( Cover test items ), You can pay attention to me , Send resume template .
2、 My own summary of the test post interview questions 50 Avenue , The structure of each question is clear , Clear thinking .( Not free )
come on. ~ Programmed life , annual income 20w Is not a dream .
Catalog
2.2.2 The purpose of the review
2.2.3 Classification of reviews
2.3.1 According to the development stage
2.3.2 According to the test technology
2.3.3 Divided according to software characteristics
2.4.1 Definition of test cases
2.4.2 What should be included in the test case
2.4.3 The role of test cases in software testing
2.4.4 Attention should be paid to when writing test cases
2.4.5 Design test cases for example
2.5.3 Performance testing tools
One 、 Preface
Learn any skill , Only a deep understanding of its purpose and significance , In order to learn more easily , Draw inferences from one instance , To guide yourself 、 Think about yourself 、 To solve themselves .
The purpose and significance of software testing : From the user's point of view, find the error of the program , Measuring software quality . And make the evaluation process according to the software design requirements .
From which aspects : Functionality 、 Ease of use 、 Security 、 Compatibility 、 Stability and so on
How to evaluate : This requires us to accumulate testing knowledge , It is convenient for us to reasonably select effective test methods in different scenarios to solve problems , See test theory for details .
Two 、 Test theory
2.1 The testing process
Requirements review : Developer 、 project manager 、 The software test requirements results obtained after the product manager's meeting
Demand determination : Determination of requirements review results by testers
Design document : After confirmation, output the design document , Describe how to design requirements
Write test cases : According to the design documents , Into test cases , These include ( Premise 、 step 、 Expected results, etc )
Execute test case : According to the test cases written , Follow the test steps , Test whether the expected results are achieved
Submit bug: Submission that fails to achieve the expected results bug
Development changes : This step is beyond the competence of the tester
regression testing : Follow the above steps a few more times
Submit test report : After it is completely completed, make an acceptance of this requirement
Version Online : Wait for the software to go online
When we know the software testing process , Let's analyze the knowledge points in each step one by one , For example, what use cases are encountered and what test methods are used 、 How to design test cases 、bug location 、bug Grade 、 Regression method, etc , Dig down step by step .
2.2 Review Overview
2.2.1 Definition of review
The results of the software project will be presented at a formal meeting ( Include documentation for each phase 、 Generated code, etc ) Submit to the user 、 Evaluation and approval of software products by customers or personnel of relevant departments .
2.2.2 The purpose of the review
Design effective test cases , Efficient testing of all aspects of software .
2.2.3 Classification of reviews
Requirements review :《 The software requirements 》《 Test requirements 》
Design review :《 Outline design 》《 Detailed design 》
Code review :《 Code specification 》
Test review :《 test plan 》《 Test case specification 》《 Defect reporting specification 》
2.3 Test categories
2.3.1 According to the development stage
unit testing : Also called interface testing , Generally, unit test developers will test the interface according to its logic after writing the interface . However, as testers, we should also understand that the purpose is to check whether each program unit can correctly realize the module functions in the detailed design description 、 performance 、 Requirements such as interface and design constraints , Various errors that may exist in each module are found .
Integration testing : Also called assembly testing . Usually on the basis of unit testing , Organize all program modules in order 、 Incremental testing .
Confirmation test : In a simulated environment , Verify whether all functions, performance and other characteristics of the software are consistent with the user's expected requirements .
The system test : The system test is in the real system running environment , Check whether the complete program system can communicate with the system ( Including hardware 、 peripherals 、 Network and system software 、 Support platform, etc ) Configured correctly 、 Connect , And finally meet all the needs of users
The acceptance test : It is the last link of software product inspection . According to the project assignment or contract 、 The acceptance agreed by both parties is based on the test and review of the whole system , Decide whether to accept or reject the system
2.3.2 According to the test technology
Black box testing : A simple understanding is to test its function , Without considering the internal logical structure , Just look at the final functional results .
White box testing : On the contrary, white box testing is to consider its internal logical structure , Test each step and find the problem , For example, the operation test of adding, deleting, modifying and querying , Function call test, etc .
Grey box testing : A test between white box test and black box test . Grey box testing focuses on the correctness of the output to the input ; Also focus on internal performance , But this focus is not as detailed as white box testing 、 complete .
2.3.3 Divided according to software characteristics
A functional test : Well understood. , Is to test whether the function of its software is realized .
Performance testing : Interaction rate 、 Whether the communication rate reaches a standard
Safety test : Test whether the software has potential safety hazards , Carrying trojan virus, etc . For example, hackers often use to modify cookie Information to simulate user login system , So as to steal information, etc .
Stability test : This is easy to understand , It depends on whether the software will exist if it is used all the time, such as flash back , I can't open it. Wait .
Compatibility test : Determine whether the specified software is applicable to the specified system , For example, apple 、 Android 、 Red Riding Hood, wait .( Less compatibility, less money , Because there are many systems now , Know everything. )
2.3.4 Other divisions
regression testing : When testing a new version of software , Repeat all test cases from a previous important release
Smoke testing : It means before a large-scale system test of a new version , First, verify whether the basic functions of the software are realized , Is it measurable . Also called testability testing .
Random test : It refers to the test based on experience and intuition of testers , Find some marginal mistakes .
Monkey test : Look around to see if there will be bug
No matter what test method to divide , The purpose is to detect bug, Improve product quality , Just for different scenes 、 We choose different test methods for different time periods , This requires us to be familiar with the theory of various test methods , So as to choose the appropriate method , Soldiers come to block. 、 Have means to resist .
2.4 Use case design
2.4.1 Definition of test cases
Concept : Design a situation , Software programs in this case , It must be able to run normally and achieve the expected results of the program design
effectiveness : Test case is an important reference for testers in the test process .
Reusability : Good test cases have the function of reuse , Make the test process more efficient , Improve test efficiency
Easy organization : Even small projects , There may also be thousands or more test cases , Test cases may have been tested in months or even years Created and used in the process .
Evaluability : From the perspective of test project management , The pass rate of test cases is the guarantee of checking code quality .
manageability : Test cases can also be used to verify the progress of testers 、 Workload and tracking / The standard for managing the efficiency of testers .
2.4.2 What should be included in the test case
identifier : Unique identifier referenced by test design process description and test program description
Test items : Describe the detailed features being tested 、 Code module, etc , It should be more specific than the features listed in the test design description . Also point out the reference Product specifications or other design documents on which test cases are based .
Enter description : This description lists all the inputs or conditions for executing the test case .
The output shows that : Describe the expected results of the test case .
Environmental requirements : It refers to the hardware necessary to execute the test case 、 Software 、 Testing tools 、 Personnel, etc .
Special requirements : Describe the special requirements necessary to perform the test .
Dependencies between use cases : If a test case depends on other use cases , Or influenced by other use cases , It should be noted here .
2.4.3 The role of test cases in software testing
1、 Guide the implementation of tests
2、 Plan the preparation of test data
3、 Writing test scripts " Design specifications "
4、 A benchmark for evaluating test results
5、 Criteria for analyzing defects
2.4.4 Attention should be paid to when writing test cases
1、 Don't design “ Exhaustive test cases ”
2、 Find a balance between detailed test cases and effective test time
3、 Good test cases should pay more attention to “ Reverse test problem ”
4、 The test case library should be constantly updated and maintained
5、 Test cases can be reused , But pay attention to data validity and environmental changes
6、 Test cases are designed , It's not written
7、 Learn more test cases designed by experienced test engineers
8、 For different requirement types and test objects , Flexible use of different test case design methods
2.4.5 Design test cases for example
problem 1: When doing adder function test , Tested 1+1,1+2,1+3 and 1+4 after , It's also necessary to test l+5 and 1+6 Do you , Can you rest assured that they are right ?
Equivalent partition method : A collection of transactions with the same properties or methods One individual in this set shows exactly the same characteristics as other personalities For the test input of a test object , An individual can be accepted or rejected , Then any individual in the set of the individual should be accepted or rejected
problem : The price of the goods = 101 Invalid price 、 The price of the goods = 0 Invalid price 、 The price of the goods = -1 Invalid goods price = 100, The payment amount = 101 Invalid payment 、 The price of the goods = 100, The payment amount = 99 Invalid payment 、 The price of the goods = 100, The payment amount = 100 No change , Please design test cases ?
Boundary value analysis : If the input condition specifies the range of values , Then we should take the value of the boundary just reached this range , And the value just beyond this range boundary as the test input data, if the input condition specifies the number of values , Use the maximum number 、 The minimum number 、 Less than the minimum 1、 More than the largest number 1 As test data
problem : stay NextDate Function , Implicitly specifies variables mouth And variables day The value range of is 1≤mouth≤12 and 1≤day≤31, And set the variables year The value range of is 1912≤year≤2050.
Cause and effect diagram : Causality diagram method is a test method suitable for describing the combination of multiple input conditions 、 The causality between constraints and output conditions , Various combinations of input conditions are analyzed , Thus, the method of designing test cases is suitable for checking various combinations involved in program input conditions .
problem : Automatic recharge of Campus All-in-one Card , There is no need for manual operation , Find all input condition numbers , Find all output condition numbers , Find all the inputs , Constraints on output
Decision table driven method : Decision table is a tool to analyze and express different operations under multiple logic conditions . Decision table is also called decision table , It is a tool for analyzing and expressing different operations under logical conditions . It can list all complex problems according to various possible situations , Be concise and avoid omission , Design a complete set of test cases .
An episode : Smart friends may have found out , The idea I wrote is to analyze step by step according to the test process
2.5 Testing tools
2.5.1 Interface testing tool
1、Postman Once you use it, you will , Know everything. ( The graduation project of the blog I wrote before has been realized postman The function of )
2、Jmter It was originally used for performance testing , But after a short time of development, it is found that interface testing is becoming more and more mature
3、Charles It could be interpreted as one HTTP proxy server 、 Reverse proxy , If the nginx Those who know may have used this thing . It allows a developer to see all the Internet connected HTTP signal communication .
2.5.2 Caught tools
1、Fiddler Is a browser capture tool , It's the check we usually use when browsing the web , It contains various requests and responses ,http Interaction between 、 The session layer 、 Network layer and other information .
2、Wireshark Is a network packet analysis software .Wireshark Use WinPCAP As an interface , Data message exchange with network card directly .
2.5.3 Performance testing tools
1、LoadRunner The common one is LoadRunner, It is a load testing tool for predicting system behavior and performance . Apply to web Test the performance of , Its characteristic is that it can generate a large amount of data , Thus, the high concurrency of postgraduate entrance examination software . And have good monitoring 、 Log and other functions .
2.5.4 Automated test tool
Speaking of this, I'm more familiar with
1、pytest python Integration test framework , If you are interested, you can see what I wrote before pytest introduction ( Although the writing is not very good , But that's enough )
2、gtest c++ Integration test framework , and pytest The same , There are only differences in grammar and effect , The future is also about to learn
3、RobotFramwork It's also python A third-party testing tool , Integrated python In many ways , Can be used on Web pages , Move APP Carry out automatic operation .
4、selenium ui Automated testing framework , If you are interested, you can see my previous blog , Fast installation enables selenium automation .
5、 There are many more like Appium、Robotium I won't introduce it later .
The purpose of these automated testing tools is to use scripts to control the platform , So as to realize the execution of test cases , Test to achieve the desired effect , Yes python If you are interested, you can also exchange and study with me .
![]()
2.6 BUG Detailed explanation
2.6.1 carry bug
1、 First of all, be familiar with bug Management tools
2、 Secondly, accurately give bug grading
3、 Finally, accurate records bug Information
2.6.2 bug Management tools
ZenTao : Zen is a domestic excellent open source project management software . Have advanced management ideas , Reasonable software architecture , Simple and effective operation , Elegant code implementation , Flexible extension mechanism , Powerful and easy to use api Call mechanism , Multilingual support , Multi style support , Search function , Statistical function . The main management idea of Zen project management software is based on the internationally popular agile project management mode ——Scrum. On the basis of following its management mode , It also integrates many demands of domestic R & D status quo , such as bug management , Test case management , Release management , Document management, etc .
JIRA:JIRA yes Atlassian Project and transaction tracking tools produced by the company , It is widely used in defect tracking 、 Customer service 、 Demand collection 、 Process approval 、 Task tracking 、 Work areas such as project tracking and agile management . Tens of thousands of teams choose JIRA Track daily affairs , And keep the team up-to-date .
2.6.3 bug Grade
Class A bug:( Fatal error )
- System crash caused by normal operation 、 crash 、 Dead cycle error reporting , Can't exit normally
- The functional design is seriously inconsistent with the requirements , The basic module is missing , The test process cannot be carried out
- Serious data calculation error
- Loss or destruction of user data
- Memory leak , The system can't log in
- Other problems that make the function untenable
second level bug:( Serious mistakes )
- Important functions cannot be realized ( for example : The function required by the user is missing , Some of the pages are not implemented , Illogical , Important chart data not developed , etc. )
- There is a wide range of mistakes , Affect the normal implementation of other important functions
- Program crash caused by unconventional operation 、 crash 、 Dead cycle ( Unconventional operation : What the user will not do when using the software )
- After the data in the system is saved, an error is displayed in the database
- The password is displayed in clear text
- There is no white screen on the page , No data
- Map data and chart data are inconsistent
Level three bug:( A general mistake )
Does not affect the operation of the product 、 Will not be the cause of the failure 、 However, defects that have a great impact on the product appearance and the next process
- The secondary function cannot be realized normally
- Operation interface error ( Including the definition of column names in the data window , The meaning is inconsistent )
for example : The column name is inconsistent with the content under the column name
- Query error 、 Data error display
- Simple input limits are not placed on the front end for control ;( Format display , For example, the format judgment in login and registration can be determined by the front end )
- No prompt for deletion
- Boundary conditions are wrong or not limited
- The system is not optimized , Data page loading is slow , Operate Caton and so on ( Performance level issues )
- Compatibility issues ( The resolution of the , System version, etc )
Level Four bug:( Interface problems )
The program is not beautiful in some displays , Not in line with user habits , Or some mistakes in words
- The interface is not standard
- The auxiliary description is not clear
- Prompt window text does not use industry terms
- There is a text error in the interface
- No prompt for operation
- Some small problems such as irregular arrangement of words
Level five bug:( Suggestive questions )
- Opinions and suggestions on product design
- Opinions and suggestions on product interface optimization
- Opinions and suggestions on the need to optimize products and enhance user experience
2.6.4 bug priority
P1: namely “ Fix it now ”, The highest priority , Problems that should be fixed immediately , Developers are required to modify this clause immediately bug, Generally, it means that the defect causes the program to completely fail to meet the needs of the product , The basic functions are obviously not realized or unavailable , Blocking the test process and progress .
P2: namely “ There is an urgent need to solve ”, Indicates that the repair of the problem is very important , It's urgent , It is related to whether the main functional modules of the system can be used normally , Include features 、 data , Or some other urgent needs .
P3: namely “ Attach great importance to ”, It means we need to solve it right away when we have time , It mainly refers to that the functions realized by the system have great requirements for the expected results , But it does not affect other functions and main core functions .
P4: namely “ Normal processing ”, Just follow your personal plan , It mainly refers to the interface , Interaction and some very small functions go wrong , But you can skip this kind of bug Keep testing .
P5: namely “ Low priority ”, Some are modifiable or non modifiable , Or it's not sure whether the modification will succeed bug, Does not affect the user experience , But it's best to modify , Generally, if you want to modify it and the time is too late, you can modify it in the later version update .
2.7 regression testing
This section covers a wide range of knowledge , The next issue will be presented separately to explain .
3、 ... and 、 summary
Learn any skill , Only a deep understanding of its purpose and significance , In order to learn more easily , Draw inferences from one instance , To guide yourself 、 Think about yourself 、 To solve themselves . If there is any mistake in the above article , Also please correct me , Welcome to exchange and study with me , Creation is not easy , Favorite points like collection and attention .
版权声明
本文为[Sober Li Bai lisage]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/04/202204220914407021.html
边栏推荐
猜你喜欢
Completely uninstall antidote 10? What if the antidote uninstall is not clean?
LSF的使用方法总结
DFS parity pruning
Full Permutation (DFS and next_permutation solution)
Realize the function of progress bar through layerdrawable
领导/老师让填写电子excel表格文档可手机上如何编辑word/excel文件填写excel/word电子文档?
Prince saves Princess (DFS)
01 knapsack problem - and deformation problem
如何“优雅”的测量系统性能
The most easy to understand service container and scope of dependency injection
随机推荐
The most easy to understand service container and scope of dependency injection
Error in face detection and signature of Tencent cloud interface
.NET单元测试第一篇:常见.NET单元测试框架有哪些?
Find number (DFS)
Jerry's CPU performance test [chapter]
W801/W800-wifi-socket开发(二)-UDP蓝牙控制wifi连接
角色个人属性英文缩写
PID精讲
计蒜客家谱(dfs求直系后代数)
(product resources) mingdeyang ad8488 module high performance digital X-ray FMC interface 128 analog channel high-speed ADC chip
修改数组(并查集)
English abbreviation of role personal attribute
Deployment of mask detection flash for yolov5
Leetcode 112 Total path (2022.04.22)
W801 / w800 WiFi socket development (II) - UDP Bluetooth control WiFi connection
Completely uninstall antidote 10? What if the antidote uninstall is not clean?
Chapter 6 uses Matplotlib to draw thermodynamic diagram
Technology cloud report: cloud computing has entered the "second half". Where is the way out for domestic cloud?
Gbase 8s fragment table management operation
Unrelated interprocess communication -- creation and use of named pipes