Tuesday, May 5, 2020
Software Testing in Auckland Companies Free-Samples for Students
Question: Discuss about the Software testing in Auckland Companies. Answer: Introduction The software program testing is an activity that is carried out when it comes to analysing of the software quality along with enhancing it in relation to offering (guide to the software developers) (Ammann Offutt, 2016). The objective of the testing is too methodically in addition to a stepwise detection of the different classes of faults that are within the minimum amount of tie and with less amount of the effort. The software testing is a relevance element of the software quality assurance and also you will find variety of company in Auckland up to forty percent of their resources with regards to testing (Ammann Offutt, 2016). The modern software systems needs to be incredibly reliable along with correct. The automatic methods for making certain that the software program is right vary from the static techniques for example the type of the software examining or perhaps the static analysis, along with the dynamic methods for instance the testing . Each one of these techniques have strengths along with weaknesses , an illustration is the model checking which is automatic , comprehensive however it could suffer from the facet of scalability (Kasoju, Petersen Mntyl, 2013). On the other aspect the static analysis, scales to the substantial programs but they might offer spurious safety measures, whilst the testing alone possibly will miss on all the essential error since they will be inherently imperfect. It is very important note that the software testing must not happen by the end of the software lifecycle, but rather must happen in the identical to the development process (Cohen, Gibbons, Mugridge Colbourn, 2003). It relates to a lot time in addition to a wide range of effort even with the utilization of the automated software program testing applications (Chauhan Singh, 2014). The software testing is an extremely difficult task, because it is difficult to determine about how the software will malfunction particularly when it has been invoked towards the end users especially in the real world (Cohen, Gibbons, Mugridge Colbourn, 2003). It has been used in the verification as well as validation that the functional requirements have been met. The software testing ensures that the software design, the codes as well as the documentations are all met by a given organization or perhaps the external standards set by the software testing the bodies which governs. This research is intended to be undertaken on software testing in Auckland (Gelperin Hetzel, 1988). The research will provide an awareness of the process of testing the software particularly in Auckland. Additionally, it would provide the software developers as well as the stakeholders on the significance of the software testing, and the techniques of testing. Literature review The software testing process is the method for the software development lifecycle that has been used when it comes to detecting on the software failures early enough when the software is been developed to be able to correct on the software before it could be used by the end users (Au, Baker, Warren Dobbie, 2008). The software testing process entails the examination and the execution to the codes of the software and make sure it is functioning as required (Grundy, Ding Hosking, 2005). Based on Gelperin and Hetzel they had presented the evolution of the software test engineering that is traced through examining on the changes in the testing process model as well as on the level of the professionalism over the past decade. The two phase model such as the demonstration and the destruction models as well as the two life cycles like evolution and prevention models have all been provided in order to describe the growth of the testing of the software (Gelperin Hetzel, 1988). These authors have also explained on the prevention orientated testing methodology based on the models. According to Richardson and Malley they proposed approaches which focusses on the usage of the specification when it came to the selecting of the test cases (Kasoju, Petersen Mntyl, 2013). They highlighted on the specification based testing through extending on the wide range of the implementation based on the testing techniques which should be applied to the formal specification languages and be able to determine these approaches to the Larch specification languages. The origins of the literature on the software testing has dated back to the early 70s , testing was conceived like an art, and it was exemplified to be the destructive process through which there was execution of the program with the intention of finding the errors. It is during this period that Dijkstra who cited on the aphorism in regards to the software testing which could only show the presence of the faults, but rather not on their absence. In the 80s there was clearly supposition in relation to testing to the status of the engineered discipline, and there was clearly have to look at the alterations to the goals from just the error discovery to much more extensive together with positive view of the prevention. Nowadays development continues to be considered to be a vast along with continuous activity via the improvement process (Gelperin Hetzel, 1988). There have been a lot study designed in the early years but it has matured into methods along with tools which help in making test design contemplating to be more systematic along with incorporate it within the means of development. There has been numerous test that has recently been offered when it comes to the industrial adoption, among which the most desired model is the V and all its variant share the variation of the minimum unit, integration as well as the system levels for the testing. Research methodology In this research there was use of the web based survey as the selected way for the research because of its convenience along with greater efficiency. There was clearly sending of email with a link to the participant to have the ability to take part in the survey. Due to internet having access to that has already been common in individuals lives with most of the software company in Auckland possessing an electronic message address, an online survey evolved into the most desired over the other techniques. In spite of its downsides the online surveys are less expensive in addition to convenient, to both the respondents and researchers. The categories which were examined were on the software testing training and experience, existing software training methods, and when it should be done. The survey included both close ended and open ended questions. Findings and Discussion Based on the findings the testing methods as well as techniques in the Auckland appears to become more constrained because of the deficiency of the resources along with experiences to the developers. Most of the companies are adapting the manual testing. The manual testing is a part of the testing process, there is certainly a trend in the direction of the automated testing. The most popular testing that has been done by most of the organization is the black box testing to be able to ensure that the software program have worked correctly depending on the requirements. The techniques for example the inspections as well as the static techniques were much less used since they require a lot of time and experience from the developers. Further result reveal that as a result of time and the high cost, many of the software organization did not utilize fully on the software testing methodologies. Some organization highlighted that they did not use any given methodology but rather they used ad hoc testing method. How software testing is carried out in Auckland Based on the software requirement specification the task program is created. The accountability of the software program testers is usually to be in a position to produce the software test plan from the software program requirement plan and the task plan (Rushby, 2005). The developers generally begin to code from the layout (Patton, 2001). The project work is split up into the numerous modules and these modules of the project are circulated among the various developers. The responsibility of the tester should be to create a particular scenario and write the test cases depending on the assigned modules. The data could possibly be maintained manually in the excel test case template or perhaps the bug tracking tools. When the developers have finalized on the personal modules those modules are after that allocated to the testers (Rushby, 2005). There is certainly then carrying of the smoke testing that could be carried out on these types of modules and in the event it neglects on these te st, the modules are after that reassigned to the respective developers for almost any fix (Myers, Sandler Badgett, 2011). In the event of any passed modules, the manual testing might be carried out from created test cases. In the event that there is certainly any bug that could be found that could be assigned to the module developer and it might get logged in the bug tracking tool, the bug fix, there is a bug verification along with regression testing which should be carried out to the other related modules (Patton, 2001). If the bug passes the strategy of verification it will be then marked as a verified along with marked as closed (Myers, Sandler Badgett, 2011). The above pointed out bug cycle could become repeated. There are several tests that happen to be performed by the Auckland developers to the various modules in addition to integration testing on the module integration (Rushby, 2005). These tests could involves compatibility testing, which involves testing of the program on the various hardware, the software platforms, and the operating system versions. Additionally, there is the load testing which is one to the software requirement specification. The system testing is carried out through the creation of the virtual client environment, if it passes on this test cases, there is a test report which is prepared and a decision is taken for releasing of that particular product. existing software testing methods In the research survey it was clear that many of the developers in Auckland used functional testing as comparison to the structural testing. They carried out black box testing instead of the inner logic testing (Myers, Sandler Badgett, 2011). The black box is any specific device which has internal information and the functioning are not recognized or maybe designed for the users. It is the testing of the software program depending on the specifications along with the output requirements and without any type of knowledge of the coding or maybe the internal structure in the system (Kuhn, Wallace Gallo, 2004). The primary purpose of this methodology is to test about how well the method might comply with a particular requirements for the method. The black box testing carries little or maybe no know-how to the internal logical framework of the given program. It aim is to make sure that all the inputs have been properly accepted as well as the outputs have been produced correctly. White box testing the internal details as well as the structure are made to become visible (Richardson, O'Malley Tittle, 1989). This method is very efficient especially in detecting as well as resolving problems, since the bugs can be found before even they could cause problems. This method of testing software process could be regarded as the knowledge of the internal structure as well as the coding. The software needed to work well, therefore the functional testing was regarded as an important aspect by many developers in Auckland (Chauhan Singh, 2014). Many of the developers in Auckland acts as the testers in the software organizations and hence the structural testing, for example the unit testing was much common. Aspect as the integration, security as well as recovery testing was also highlighted by many respondents. Dynamic and static testing The dynamic testing involves the execution of the software program. This might consist of the box testing, white testing along with the hoc testing. In the study not every respondent pointed out they would do the black box testing however they also ticked the dynamic testing (Sung Paynter, 2006). This might reveal certain misunderstanding in relation to the conditions in the questionnaire or maybe some inconsistency which is within the software testing process (Majchrzak, 2010). This can be very evident in the literature exactly where the conditions were not used in a regular manner. Nevertheless, it is extremely distinct from the survey done just that the dynamic testing was the most typical compared to the inspection or maybe the static testing methods (Majchrzak, 2010). The technique of inspections, syntax and walkthrough could be time consuming and this might be the reason as to the reasons many developers in Auckland overlooked on these processes. Manual and Automated testing The automated method is becoming more popular but based on the results the manual testing is much more common in Auckland. One method used for automatic testing is the Ranorex (Richardson, O'Malley Tittle, 1989). This is a simple but yet a comprehensive as well as a cost effective tool which is used in the automatic testing. It is the best alternative as comparison to the other testing tools since it tests the programs from the perspective of the users, using the standard language and the common programming techniques such as the C+ and the VB.net (Hao Mendes, 2006). The method does not require any understanding of the scripting language, since it is coded in pure. Net code. Software testing strategies The software testing strategies integrate on different software test case design methodologies to the well planned series of the steps which result in the successful testing of the software (Hao Mendes, 2006). The software testing strategies are significant to testing. Some of these are as follows: Unit testing This is done at the lowest level. This testing is intended to test on the basic unit of the software, that may be module or perhaps component (Majchrzak, 2010). This testing is on the levels of the testing that contribute in order to make the big picture of the testing to be the whole system. Integration testing This is done when two or perhaps more tested units have been combined to a large structure (Majchrzak, 2010). The testing is usually done on the interfaces which can be between the components and the larger structure which is being constructed. System testing This testing usually intends to test on the end to end quality of the entire system. It is based on the functional as well as the requirements specifications of a given system (Hao Mendes, 2006). The quality attributes such as the security, maintainability as well as the reliability are all checked. Acceptance testing This is carried out when the complete system has been handed over to the clients or perhaps the users from the side of the developer (Verma Arora, 2014). Figure 1: This diagram highlights the various strategies for testing When is software testing done Testing of the software can be done at the start of the development of the software life cycle. Based on the respondent in Auckland highlighted that most of the errors which are identified are found in the testing phase that is already been introduced in the requirement of perhaps the design phase (Schwieren, Vossen Westerkamp, 2006). The defects which are identified later in the software development are very expensive to fix as comparison to the defects found in the early stages (Kaur Singh, 2014). The testing needs to start early in order to avoid the introduction of any defects in the early phase. The testing of the software early helps to achieve cost effectiveness. The testing start early in the development of the software in order to solve the problem as early as the bug are found, they become cheaper in order to fix them. In the requirement phase in case there is any issue or perhaps a conflict is found it would take little time to fix on the issue and it becomes much cheape r than fixing the bug in the actual testing (Schwieren, Vossen Westerkamp, 2006). If it was in the maintenance phase it means it costs more after the product is going to be produced (Kaur Singh, 2014). The testing should be designed as much as possible in order to find on the defects of the highest severity as well as the highest relevance to the users (Sung Paynter, 2006). Testing at the start helps to validate that the system has been developed based on the requirements of the users. The validation should be done to ensure that the developers are building on the right system, as well as helping in the making of the decision, which is important for the risk management. Conclusion The software testing is becoming very important when it comes to the development of the software and its importance has been recognized in the information technology industry. Nonetheless, the clear common guidelines as well as the standards which govern the software compact nature of numerous software advancement firms, most of the key elements were neglected and testing has not gained much recognition it should get. This continues to be predictable in several to the numerous developers particularly in which they had to be multi-skilled and testing function needs to be separated. The quality is the major focus to any of the software engineering project and without measuring, it could not be possible to understand the degree of the quality in a particular software. The strategies to the measurement of the quality are software testing techniques. This research has related to the various king of the testing technique which could be applied in the measuring of the various quality attrib utes. It is important to constantly to be able to summarize on the new achievements and propose on the various ideas to promote the study on software testing process. On the recommendation the test team should focus on finding on the defects in the software such as the deviation from the software requirements specification or perhaps any variance from the output that are required. Additionally, the developers should focus on the performance, the reliability in order to improve on the quality of the software. References Ammann, P., Offutt, J. (2016). Introduction to software testing. Cambridge University Press. Au, F. T., Baker, S., Warren, I., Dobbie, G. (2008, January). Automated usability testing framework. In Proceedings of the ninth conference on Australasian user interface- Volume 76 (pp. 55-64). Australian Computer Society, Inc.. Chauhan, R. K., Singh, I. (2014). Latest research and development on Software Testing Techniques and Tools. International Journal of Current Engineering and Technology, 4(4). Cohen, M. B., Gibbons, P. B., Mugridge, W. B., Colbourn, C. J. (2003, May). Constructing test suites for interaction testing. In Software Engineering, 2003. Proceedings. 25th International Conference on (pp. 38-48). IEEE. Gelperin, D., Hetzel, B. (1988). The growth of software testing. Communications of the ACM, 31(6), 687-695. Grundy, J., Ding, G., Hosking, J. (2005). Deployed software component testing using dynamic validation agents. Journal of Systems and Software, 74(1), 5-14. Hao, J., Mendes, E. (2006, July). Usage-based statistical testing of web applications. In Proceedings of the 6th international conference on Web engineering (pp. 17-24). ACM. Kasoju, A., Petersen, K., Mntyl, M. V. (2013). Analyzing an automotive testing process with evidence-based software engineering. Information and Software Technology, 55(7), 1237-1259. Kaur, M., Singh, R. (2014). A Review of software testing techniques. International Journal of Electronic and Electrical Engineering, 7(5), 463-474. Kuhn, D. R., Wallace, D. R., Gallo, A. M. (2004). Software fault interactions and implications for software testing. IEEE transactions on software engineering, 30(6), 418-421. Majchrzak, T. A. (2010, January). Best practices for the organizational implementation of software testing. In System Sciences (HICSS), 2010 43rd Hawaii International Conference on (pp. 1-10). IEEE. Myers, G. J., Sandler, C., Badgett, T. (2011). The art of software testing. John Wiley Sons. Patton, R. (2001). Software testing. Sams publishing. Richardson, D., O'Malley, O., Tittle, C. (1989). Approaches to specification-based testing (Vol. 14, No. 8, pp. 86-96). ACM. Rushby, J. (2005, October). Automated test generation and verified software. In Working Conference on Verified Software: Theories, Tools, and Experiments (pp. 161-172). Springer Berlin Heidelberg. Schwieren, J., Vossen, G., Westerkamp, P. (2006). Using Software Testing Techniques for Efficient Handling of Programming Exercises in an e-Learning Platform. Electronic Journal of e-Learning, 4(1), 87-94. Smith, J., Tessler, J., Kramer, E., Lin, C. (2012, September). Using peer review to teach software testing. In Proceedings of the ninth annual international conference on International computing education research (pp. 93-98). ACM. Singh, R., Arora, V. G. (2013). Practical approach for model based slicing (Doctoral dissertation). Sung, P. W. B., Paynter, J. (2006). Software testing practices in New Zealand. In Proceedings of the 19th annual conference of the national advisory committee on computing qualifications (pp. 273-282). Verma, V., Arora, V. G. (2014). Code and Model Based Test Sequence Generation for Multithreaded Programs (Doctoral dissertationn the companies in Auckland?
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.