Joke Collection Website - Mood Talk - The testing of open source software is different from traditional software.
The testing of open source software is different from traditional software.
If we really want to use the term traditional software industry, it means that users need to install client-side software, or software that customers' administrators need to deploy in the computer room, whether it is CD-ROM or hardware, or a system tailored for customers.
Change and invariance are always eternal themes. Let me talk about the different places I saw first. The difference between Internet industry and traditional software;
1. The biggest difference is that many Internet products are deployed and operated by themselves, and users can use them with a thin client.
The thin client here is a browser, an App, or a client that needs to be installed, but the core data and business logic are mainly in the computer room of Internet companies, in IDC and in the cloud. Before C/S,
The main difference between enterprise systems based on B/S architecture lies in the range of people to be served and who will operate and maintain such systems. Therefore, naturally, there is much more work in this area.
In order to narrow down the scope of testing, we need to consider the production environment. For example, there are the following aspects:
A. how to monitor the availability of production environment functions?
This needs to be done together with the operation and maintenance, but the operation and maintenance is aimed at more general parts, such as the resource usage, traffic and bandwidth of the machine, but it is biased towards the product business level, such as whether there are functions available.
Business testers need to design and develop an automation system to monitor.
B. How to release the function to the official operating environment (production environment)
Generally, it will be released directly after testing, so it is not as long as traditional software, including internal testing, external testing and other processes, and what I learned is that many Internet products based on it average one day.
There are multiple versions, big or small. So the release may become the work of testers, with the support of related systems. What needs to be considered here is the common gray scale release based on various conditions, so that some users can use it first.
After release, the production environment needs to be verified.
C. How to ensure or verify that the test environment and the production environment are synchronized?
Once the internet is in this mode, the problem of test environment will be more prominent, because there are many systems involved, and some interfaces with external systems may be difficult to build or use mock by themselves. On the other hand, if the test environment is good, the production environment is also good. Verification and synchronization need corresponding mechanisms and tools.
Narrow it down to development. Some features of the Internet should be considered, such as the following aspects:
A How to locate quickly, the problem lies in which module or modules to design according to the demand, and gives the solution.
Generally speaking, newly added functions or modules are easier to plan, design software, develop and test like traditional projects. However, if it is a problem in a production environment, you need to be very familiar with the original business and software architecture, and be able to quickly locate the page where the problem lies and the pages involved. From the perspective of an Internet engineer who switched from traditional software, a web program is actually a collection of software. Each web page is an independent applet. They are either very independent and only jump through a link, or a group of pages form a collection of programs to achieve a specific function. After all, multiple dlls exist independently. Therefore, from the perspective of traditional software engineers, a web program should be managed by the concept of a set of management programs. How to do it specifically? First of all, the technical personnel responsible for development are divided into three categories, one is the senior coder, preferably the original module developer. They are very familiar with the requirements of modules and the design and implementation architecture, but they only analyze the requirements of feedback CR. Shield some unreasonable modification opinions, analyze the requirements to be modified, design modification methods, and judge the scope of modification. The second type is an intermediate coder, who only communicates with senior coders and carries out his design ideas. The third category is that junior coders are responsible for communicating with senior coders to understand the scope of revision. Do a good job in the self-inspection of the developer's modification of the intermediate encoder, complete the relevant documents, and be reviewed by the advanced encoder.
B how to judge whether the developed function is ok?
In the audit of senior coders, it is necessary to confirm whether the implementation of coders conforms to the original design through the documents of three types of coders. Of course, it is best to communicate with the second type of coder in advance when designing. With the continuous tacit understanding of the team, junior coders can quickly master business logic and self-test methods, and be familiar with the tools used by developers. Grow up and then become an intermediate programmer. Colleagues' intermediate coders are growing while realizing the design, so that they can be competent for the work of requirements analysis and software design and become senior coders, so that the whole small team is very powerful. This method is similar to the mandarin duck array of Qi Jiguang, a famous anti-Japanese, and is specially used to deal with the enemy with strong personal skills and high martial arts.
How to ensure the stability of web programs in production environment
Reducing publishing times is the most effective measure to ensure the stability of web programs, but if it is an urgent problem, it can be published on the same day. For example, we are providing technical support to the United States. We can use noon as the test deadline and release it at 5: 00 on the day when the test passes at 2: 00 noon. If it fails at 2 o'clock, it will be postponed until the next day.
2. The pace of Internet products is very fast.
Unlike traditional client or server software products, the cycle may be half a year, a year or even longer. In this way, there will be enough time for project planning, requirements review, then outline/detailed design, then test design test cases, and then different test cycles, as well as sufficient time for preparing test environment and automated testing.
At present, it is not realistic for Internet products to do so. This is also a great challenge for testers. You may see that a requirement will be tested in a few days, and the use case will be opened temporarily, so there is no time for automation and not much time for test design. Then the function will go online in two days. Without personal experience, it is difficult to understand the difference brought by this speed. So how to ensure the coverage and quality of the test in such a short time, and how to reduce the omissions? This is a realistic question, or requirement, and there are some measures, but there is actually no good answer.
More people take the test.
In Internet companies, the proportion of testing vs development is very low, and 1:6 and 1:7 are very common, even higher. How to ensure the quality under such a ratio? There must be more ways. take for example
A. developer's self-test.
Testing needs more time because the quality of the code is not good enough. There was a lot of discussion and a lot of code pulling. Therefore, it is a very important aspect to improve the code quality of development submission. Some companies do this through development.
Personnel's compulsory unit tests are guaranteed, and some are guaranteed by self-test at the functional level. These can be reflected by some data, such as the number of times the same version of the code has been pulled, or the pass rate of test cases, and so on.
B. product or operator experience.
Unlike traditional software products, many Internet products are not provided by a product manager. The product, or product manager, is a team, and everyone is responsible for putting forward the requirements. In addition, many requirements may come from the operation team, related to the business, or the opening of different systems. Every product manager or operator needs to try the product in the experience environment after the developer realizes the corresponding functions. This is called experience to see if these functions are what he wants. This can ensure that testers have no obvious needs to understand problems before testing, and avoid wasting manpower and time in testing.
C. pre-release review.
Different roles come in to see if there are any problems with a tested job, as well as problems that need attention when publishing, environmental problems, configuration problems, data problems and so on. Some of the above practices may be helpful, but how to promote it, if tested, needs processes and tools to support it.
4. Some of them are free of test.
Not everything released into the production environment needs to be tested, and some changes don't need to be tested. There is no certain standard for this, it depends on the specific release situation and the maturity of the product and team. For example, some temporary activity pages, some small pictures or style changes, some minor repairs and so on. After the release, go to the external network for verification.
What can be avoided is actually a very complicated problem. Of course, there are risks, but the efficiency improvement is also obvious.
5. Challenges brought by massive users
Actually, there are many. Here are a few:
A. How to guarantee or verify performance
The performance test of traditional software is relatively simple, and it is easier to build an environment and simulate traffic. A product of the Internet may have hundreds or even more servers, which are deployed in many places and many layers. Due to various factors, such as advertising and promotional activities, traffic can suddenly rush to a high level. Therefore, the practice in this respect will be different, full simulation is not realistic, and as mentioned above, it is released quickly, so there is not much time to do performance tests repeatedly. So how to do a lightweight performance test is also a big topic.
B. browser compatibility.
There may be many kinds of browsers used by users, including IE6, the rocket-like version update speed of IE9, Chrome and Firefox, and many domestic browsers. It's a big challenge to cover all of them, but it's impossible, but the product team definitely wants the test to cover more. For some enterprise products, it can be claimed that only a few products are supported, but Internet products are difficult to do, which is equivalent to giving up some users. How to design a strategy? Is there any technical means?
C. How to ensure the robustness of the changed things without input restrictions and arbitrary operations.
A problem caused by a small change can affect countless users, and many times it will be discovered immediately. That's still a lot of pressure. The whole repair process is also live operation, so there is not much environment and time to adjust slowly. How to ensure the maintenance quality?
Step 6 solve the problem
One advantage or feature of Internet products over traditional products is that problems can be fixed quickly, because users can be affected quickly, and there is no need to wait for users to patch or patch or even install new versions. In many cases, the time from the occurrence to the repair of this problem is very short, which is really not noticed by most users. Sometimes it will be quick &; Dirty excuses, but it's usually
The problem of production environment is listed as an evaluation index. Moreover, some problems are not minor problems, and accidents may occur. In fact, for such products, testers are under greater pressure to miss the test.
7. Differences in the selection of testing tools and technologies
Probably because of some characteristics of Internet products, major companies are using a large number of open source and internally developed platforms and systems. Accordingly, the platforms and tools used in the test are mainly these two kinds, either open source tools (or some modifications may be made) or internally developed tools. In contrast, the traditional software industry will buy some commercial testing tools, such as tools for performance testing, coverage or code checking, and a management platform for test cases and defects.
At present, I understand that several major Internet companies in China are undergoing transformation and self-research. It is not necessarily advantageous to list a large number of experiences in using large tools in their resumes. For newcomers, it takes a lot of time to learn and get familiar with these platforms.
The above lists some differences compared with the traditional software industry, but for testers, the similarity between the Internet industry and traditional software lies in:
1. You also need to have a good understanding of products and business.
For testers, if they don't know the product and business, it is difficult to carry out testing work, because even the most basic right or wrong (bug or not) is difficult to judge. Of course, except for some obvious mistakes, such as js errors, this defective product can be found during the experience, or until it is discovered by users. So we still need to spend a lot of time and energy to get familiar with the product business. From this point of view, there is no big change, just different fields. This difference is caused by different products, not by traditional software or the Internet.
2. You also need to know the technology of the product.
This is actually a little similar to the above. Testers need to know the technology used in product development, which is very related to in-depth testing and even the application of many testing technologies and tools, such as performance analysis, memory leak discovery, coverage analysis and so on. Without learning and understanding this, a lot of work cannot be carried out. There is no change in the direction, and these things need to be studied and practiced to better understand. However, the specific technology may be different. For example, Internet web products may generally use JS, PHP, Java, C++ and other languages, as well as various web servers, caches, proxies and so on.
3. Specific test technology
The technology of product development mentioned above actually has a testing technology. In fact, there are many similarities or even similarities between this piece of refinement and traditional software development. For example, we do static static code analysis, local performance testing methods and tools, coverage tools, automation tools and frameworks, monitoring tools and so on.
From this perspective, there is not much difference in technology. Of course, the Internet is special, such as many web-based systems, which are distributed and multi-layered, which will put forward some requirements for tools. This difference is actually not very big, because many traditional server software is also like this.
4. Test design method
As mentioned above, the whole process must be lighter and faster because of the different pace of product release, but when testing a specific function, the problems that need to be considered in the design and implementation of use cases are actually not much different from the traditional ones. Because everyone is facing the same problem at this time, how to test this function of this software. So some ideas and methods can still be used.
On the whole, the local differences are relatively small, but the differences involving large forms and processes will be relatively large.
It may also be because of this reason that many people from traditional software to the Internet can quickly merge and start to play a role, and a few years later, most people from major Internet companies are from so-called traditional software companies.
I believe that the development speed and opportunities in different fields are different, which is one of the reasons why many people have joined the Internet industry in recent years. This is just like the so-called driving force of the market on resource allocation in economics, which is normal. On the other hand, people will have an illusion that they will become stronger immediately if they switch to a fast-growing industry. In fact, calmly, it will not be like this. Just a wave. Real skills and abilities will not become strong or profound because you change a field or industry. If you want to get such a promotion, you must learn more, practice and think, and communicate with others.
The Internet products mentioned above, in fact, are sometimes a false proposition, because all major Internet companies have traditional software, such as Tencent, Baidu and Ali, all of which have client products, and there are quite a number of them, and some have C/S architecture products. Foreign Google also has desktop products such as chrome and picasa, and facebook also has an IM client. Therefore, technologies such as the development and testing of GUI products, and methods and capabilities of servers similar to enterprise products are still very much needed. Of course, these products are all networked, so there are some differences, but they are not as big as expected.
Another problem, sometimes people use the name of internet software to avoid some things, such as some imprecise or chaotic places, which all comes down to the characteristics of the Internet. This is a question of "degree", so we should distinguish it ourselves.
Another question, what advice do you have for people who are new to Internet testing? The following is also self-encouragement.
1. Face up to the changes brought by this difference. Some things mentioned above are really different, so we should actively learn and understand them.
2. Work hard to learn product-related knowledge, including related development technologies, so as to carry out the work better.
3. always reflect. I used to study a thing clearly in one environment, but the old experience and knowledge may not be fully applicable after changing the environment. So let's not talk about the old us. Don't copy mechanically, but understand the situation and see what can be learned after understanding the problems. Some references may be more reliable.
- Previous article:Lost sadness: he wants to run for his own happiness, while she is still wandering.
- Next article:Tell me about that cow.
- Related articles
- Summary of annual work of hospital equipment department
- 20 chat skills that people with low emotional intelligence must see.
- What about the graduate students of Xiamen University Law School? Yes, I want to take the exam. What exactly is it? Is there any subsidy or something?
- Friends circle comments on how fairyland on earth replies to each other.
- Talk about the mood of sending people to the station
- Thank you very much. It means it's best to use local characters for names, right? What is the name of the surname? What are the local characters?
- Shiba Inu has won the favor of a large number of dog lovers for its lovely appearance. Is the Japanese Shiba Inu high in IQ?
- Happy Teachers' Day.
- The touching story of War of Resistance against Japanese Aggression's period.
- Sentences suitable for morning running and making friends.