Mobile in general is such niche area and glad that at LinkedIn, I am getting to explore as well as expand new horizon.
My team is focus on supporting Mobile native apps, hybrid app as well as mobile web software test cycles.
I may not be able to write more here but look forward to a blog from me on engineering.linkedin.com
Tuesday, August 31, 2010
Tuesday, July 6, 2010
Exploratory Testing - Innovative approach
Exploratory testing is an approach to software testing that is concisely described as simultaneous learning, test design and test execution. While the software is being tested, the tester learns things that together with experience and creativity generates new good tests to run. Exploratory testing is often thought of as a black box testing technique. Instead, those who have studied it consider it a test approach that can be applied to any test technique, at any stage in the development process. The key is not the test technique nor the item being tested or reviewed; the key is the cognitive engagement of the tester, and the tester's responsibility for managing his or her time. (Ref: Wikipedia)
In a resource crunch situation, especially, when the new features are coming in to huge extent, this innovative approach can make wonders! However appropriate planning, organizing and motivation is desirable to make this approach a success.
In short, the approach, involves, getting various stake holders like engineering team members, product managers, UX team members, customer field representatives together and perform an exploratory testing... on given feature or product. It could be simple web 2.0 product or it could be wireless device...does not matter.
As long as QA manager/lead outlines proper strategy....and a step by step representation of how to effectively perform exploratory testing or corner case testing... Once you have such step by step guide you can always give a preso to above stakeholders and get them up to speed with concept of exploratory testing. And you can pin point exact ways to make it effective and get best out of it!!
When I had conducted this approach, I had come up with 10 steps of effective ways.... think like an end user, act like an end user....relevant to the product that I wanted to get tested thoroughly,... Made sure to get buy in from VP/ Director initially by explaining them approach, impact and result! Rolled it out to engineering. Then got buy in from product manager(s). Rolled it out to them and then field representatives as they deal with customers and they know the issues or most common operations by customers.
Overall to avoid duplication of bugs, we have had everyone perform testing at the same time..no matter where they are located within USA :) And then set up IRC channel where constant communication of issues seen was going on to avoid duplication of bugs.
Result..we actually end up finding some of the corner case issues, high priority issues! We ended up adding almost 35+ test scenarios in our test repository and automating the same!!
This was very well received by my engineering team as well as product manager. Helped save a lot of QA time of performing black box - exploratory testing ..
In a resource crunch situation, especially, when the new features are coming in to huge extent, this innovative approach can make wonders! However appropriate planning, organizing and motivation is desirable to make this approach a success.
In short, the approach, involves, getting various stake holders like engineering team members, product managers, UX team members, customer field representatives together and perform an exploratory testing... on given feature or product. It could be simple web 2.0 product or it could be wireless device...does not matter.
As long as QA manager/lead outlines proper strategy....and a step by step representation of how to effectively perform exploratory testing or corner case testing... Once you have such step by step guide you can always give a preso to above stakeholders and get them up to speed with concept of exploratory testing. And you can pin point exact ways to make it effective and get best out of it!!
When I had conducted this approach, I had come up with 10 steps of effective ways.... think like an end user, act like an end user....relevant to the product that I wanted to get tested thoroughly,... Made sure to get buy in from VP/ Director initially by explaining them approach, impact and result! Rolled it out to engineering. Then got buy in from product manager(s). Rolled it out to them and then field representatives as they deal with customers and they know the issues or most common operations by customers.
Overall to avoid duplication of bugs, we have had everyone perform testing at the same time..no matter where they are located within USA :) And then set up IRC channel where constant communication of issues seen was going on to avoid duplication of bugs.
Result..we actually end up finding some of the corner case issues, high priority issues! We ended up adding almost 35+ test scenarios in our test repository and automating the same!!
This was very well received by my engineering team as well as product manager. Helped save a lot of QA time of performing black box - exploratory testing ..
Monday, June 21, 2010
Selenium wait()
Selenium wait() not defined ? What will happen ?
Selenium uses the browser to make requests and process the server response. In short, selenium asks for a page and server sends back the response.
The browser then constructs a DOM tree out of the response. Selenium then parses this DOM tree and looks for elements as per the test statements.
Short example
Step 1 --> @selenium.open("www.google.com")
Step 2 --> @selenium.wait()
Step 3--> @selenium.is_text_present("Google ...")
Here the request is Step 1.
Now assuming that the server is not loaded at all, the network latency is very minimal and the client machine has a very fast processor, the time from the first request to receiving the response will STILL be atleast a few miliseconds. So not considering the network latency and delayed response from the server, some time is definitely required for the browser to generate a DOM tree out of the response and then ready the page to be rendered.
If we do not allow for a wait period, however small it maybe due to ideal network and server load conditions, then selenium will jump from step 1 to step 3. At this point, the DOM tree is not ready and selenium will NOT find the text "Google ..." in the DOM tree. Thus, our test will fail.
For any test environments, the server response times could be large and selenium has to wait for the response to be completely consumed by the browser and build a DOM tree. Even if we were to make the test environments extremely fast and run at almost no load, there will be some amount of time required for DOM tree creation and parsing :)
Hence wait() is a basic required function for Selenium and can not be avoided :(
Selenium uses the browser to make requests and process the server response. In short, selenium asks for a page and server sends back the response.
The browser then constructs a DOM tree out of the response. Selenium then parses this DOM tree and looks for elements as per the test statements.
Short example
Step 1 --> @selenium.open("www.google.com")
Step 2 --> @selenium.wait()
Step 3--> @selenium.is_text_present("Google ...")
Here the request is Step 1.
Now assuming that the server is not loaded at all, the network latency is very minimal and the client machine has a very fast processor, the time from the first request to receiving the response will STILL be atleast a few miliseconds. So not considering the network latency and delayed response from the server, some time is definitely required for the browser to generate a DOM tree out of the response and then ready the page to be rendered.
If we do not allow for a wait period, however small it maybe due to ideal network and server load conditions, then selenium will jump from step 1 to step 3. At this point, the DOM tree is not ready and selenium will NOT find the text "Google ..." in the DOM tree. Thus, our test will fail.
For any test environments, the server response times could be large and selenium has to wait for the response to be completely consumed by the browser and build a DOM tree. Even if we were to make the test environments extremely fast and run at almost no load, there will be some amount of time required for DOM tree creation and parsing :)
Hence wait() is a basic required function for Selenium and can not be avoided :(
Saturday, June 19, 2010
How to be innovative and how to keep yourself motivated
At work some times it could be possible that you end up working on certain project and may end up performing kinda similar tasks w/very little variations... So would that become monotonous ?
Do you think if it becomes monotonous..you may loose productivity to some extent and to help performing excellent at work, you need your motivation to be boost ?
Well, here is how I keep myself motivated - whether its work or cooking in kitchen. Coming from an Indian background, I almost end up preparing similar kinda breakfast with little variations...my family may get bored with same taste over and over again so I try to add different spices or motivate myself to try creative recipes for the same dish :) Well that truly helps!
I found below an interesting article published which helps self-motivation:
http://business.timesonline.co.uk/tol/business/management/article5883575.ece
Do you think if it becomes monotonous..you may loose productivity to some extent and to help performing excellent at work, you need your motivation to be boost ?
Well, here is how I keep myself motivated - whether its work or cooking in kitchen. Coming from an Indian background, I almost end up preparing similar kinda breakfast with little variations...my family may get bored with same taste over and over again so I try to add different spices or motivate myself to try creative recipes for the same dish :) Well that truly helps!
I found below an interesting article published which helps self-motivation:
http://business.timesonline.co.uk/tol/business/management/article5883575.ece
Friday, June 18, 2010
JMeter or Selenium - Performance Testing of Web App
Some one recently asked me an interesting question "which tool better for performance testing for given web app - Selenium ? or any other open source ?"
Well here is my take
Well here is my take
Tuesday, June 8, 2010
Find bugs - Static Analysis To Look For Bugs In Java code
Find Bugs - A static analysis tool to find logical error in given code snippet. Basically it helps find bugs in Java code. This comes as an Eclipse plug-in.
There is a way you can integrate Find bugs into the source control you are using for example Perforce.
This should be integrated on each and every development environment of developer's whether Eclipse or IntelliJ. As you go on writing code, this tool will immediately display errors which could cause eventually potential bugs with coding right away. So it saves time of developers handing over code to QA, QA performs testing and reporting back these bugs. Here is published material bu Find Bugs community as it was used @Google for product AdWords:
Published Material:Find Bugs Approach As Published
There is a way you can integrate Find bugs into the source control you are using for example Perforce.
This should be integrated on each and every development environment of developer's whether Eclipse or IntelliJ. As you go on writing code, this tool will immediately display errors which could cause eventually potential bugs with coding right away. So it saves time of developers handing over code to QA, QA performs testing and reporting back these bugs. Here is published material bu Find Bugs community as it was used @Google for product AdWords:
Published Material:Find Bugs Approach As Published
Saturday, June 5, 2010
Methodology - Agile Testing Approach
What does Agile Means:
- Being Agile means creating an environment where change is embraced
- Changes in requirements, system knowledge, and /or organization are considered part of normal software development
- Agile is about focused collaboration between customers and developers
- The main goal is clean code that works, at a minimum investment
Why Agile: Reference: [AgileManifesto01] “Individuals and interactions over processes and tools Working software over comprehensive documentation. Customer collaboration over contract negotiation. Responding to change over following a plan. That is, while there is value in the items on. the right, we value the items on the left more”
When does Agile Makes sense:
- Rapidly develop and deliver software that
- meets business needs in the face of an
- unpredictable future
- Ability to change your mind
- Early availability of business value
- Option to cancel at any time yet still have value
- Handle uncertainty
- Visibility to & feedback from the customer
When does Agile makes no sense:
- Uncertain and/or unstable success criteria
- Uncertain and/or unstable requirements
- Immediate access to business expertise
- High value in early release of partial functionality
- Project can be “self-contained”
When does Less Agility makes sense:
- Knowable, stable project goals and requirements
- Like version 3 of a well-established application
- Customer can't absorb frequent releases
- High effort of data conversion, user training, …
- Team is too large, dispersed, or high turnover
- Poor team dynamics
- Lack of customer representation and/or poor
- customer relationship
- Dependence on external supplier's
- Long-term maintainability is important
- Life- or mission-critical products
There's more than one way to be Agile:
- Extreme Programming
- Scrum
- Crystal
- Agile Modeling
- Dynamic Systems Development Method
- Feature-Driven Development
- Adaptive Software Development
Is Agile Appropriate:
- §Learning objective
- §Practice evaluating projects to see why they would or
- §wouldn’t be good candidates for agile development
- §Procedure
- §Read the Project Profiles in the Labs section
- §Discuss the projects in your groups
- §What characteristics of the projects make them good
- §candidates to be run as agile projects?
- §What characteristics make them not so good
- §candidates to be agile projects?
- §Extra Credit: Analyze your current project's
Test A Little Code A Little:
- §You don’t need to write all the test cases first
•1. You have to create of one test that the current code won’t pass
•2. Write code to pass the test
•3. Go back to step 1 - §If it is hard to write a test there may be a design issue
- §Each round of test & code includes refactoring of the previous code
Frequent Build and Test:
- §Completely build the product and run it through a series of tests to verify basic operation
- §“Daily build and smoke test”
- §“Continuous integration”
- §Works well with large volume projects
- §Lowering integration risk
- §Exposing big integration errors quickly
- §Tracking project progress
- §Extra effort/overhead
How Frequent:
- §Not more than a couple of hours between builds
- §Build should take 10 minutes
- §Asynchronous builds most common
- §Check stuff in, the automatic build process
- §notices, sends out email of result
- §Synchronous builds give team a chance to reflect
- §Builds scheduled at certain times for all programmers
Multiple Builds:
- §Different builds accomplish different goals
- §Short, small builds on the test first approach
- §Overnight builds to test full integration
- §Weekly run more complete tests
- §Automation here is key
- §Agile sees this as a worthy area to spend
Test Coverage Criteria:
- §How do I have confidence that my set of test cases is “good enough”?
- §Input and output domain coverage
- §Boundary value testing
- Decision (Branch) coverage
- Agile Testing good for Agile development projects; can work on conventional projects too.
- Don’t implement Agile testing as a whole, but adapt its most valuable concepts
- Testers should be active members of the team.
- Testers often hesitate to speak up during team meetings, share ideas, interact with developers.
- Agile only works when there is lots of both formal and informal communication within a team.
§With developers
§With CSRs
§Business Analysts.
Testers and developers are working together.
§Share office
§Testers assigned to help particular developers
§Test plan evolves through a series of short “drop-in” meetings
§Benefits of pairing with developers:
- developers gain insight into potential errors
- testers gain insight into constraints and opportunities.
- together can advance automated testing.
- Grey box: - understand relationship btw parts of the systems.
- understand bugs: what were the root causes?
- what needs to be retested?
Test Status is reported via simple to read charts that answer specific question “What part of code can we stop worrying about?.”
Stand up reports.
Conversation with a customer is as important as with developers.
–Remember that customer are trying to figure out what they need, want and are getting, in large part, by trying out the working code.
–Get feedback from CSRs -> create tests
–Participate in usability testing
Remember: “ …thinking does not take place inside our heads … Most of our mental activities need external resources.”
Keep in mind that sometimes design docs can be flawed.
Documents can’t be an adequate representation of the working code.
View them as: interesting texts, partly fictional, often useful
Active communication is the key to a successful test plan
First, Waste No Time. Evaluate risky areas and test them first
- We gain an understanding of the product we're testing to the point where we can imagine what kinds of problems are more likely to happen and what problems would have more impact if they happened. Then we put most of our effort into testing for those problems. Agile Testing is concerned with uncovering the most important information as soon as possible.
Mission. What's more important? Writing test cases or doing testing?
- In Agile Testing we don't start with a task ("write test cases"), we start with a mission. Our mission may be "find important problems fast". If so, then writing test cases may not be the best approach to the test process. If, on the other hand, our mission is "please the FDA auditors", then we not only will have to write test cases, we'll have to write certain kinds of test cases and present them in a specifically approved format. In our case it’s both.
Skills.
- Knowing the product lets you perform “out of the box” testing
Exploration.
- Use exploratory testing. We prefer to let the next test we do be influenced by the last test we did. This is a good thing, because we're not imprisoned by pre-conceived notions about what we should test, but let ourselves develop better ideas as we go.
Teaming.
- Agile Testers cheat. That is, they do things that our former elementary school teachers would consider cheating: we figure things out in advance where possible, we borrow other people's work, we use every resource and tool we can find. Example: Pair testing: two heads, one computer. This idea has proven valuable in the practice of Extreme Programming, and it works for testing just as well. In our experience of normal testing, testers usually work quietly and alone, rather than hunting for bugs like a pack of rapid wolves. Again the message of this presentation is not to try to adapt Agile testing as a whole, but extract and implement the most useful techniques of Agile testing.
Some of the stuff is being done already.
- Testers have stand up meetings
- Some Interaction with CSRs (manager, team leads)
What we don’t do yet:
- Closer interaction with developers.
- Closer interaction with CSRs. (primary testers)
- Robust testing, “out-of-the-box” thinking. (for primary testers)
- Grey box: understanding of the system.
- Automation: combine unit tests and our automation tests.
- Testing in pairs.
Increase quality of the product. Find bugs faster.
Get more exposure for QA
Get better understanding of components.
Interact with developers more, which is always good.
Get better understanding of the working code.
Deliver marketable product earlier
Friday, April 2, 2010
Automated Testing:Hadnling/Managing ever changing UI - Use of CheckSum
Following post has a bug and an unanswered question - How would you handle dynamically updated web app. I do have some solution in my mind and just need to try it out before throwing as a post. So update soon.... ************
Firstly we need to understand what is Checksum. According to wikipedia:
A checksum or hash sum is a fixed-size datum computed from an arbitrary block of digital data for the purpose of detecting accidental errors that may have been introduced during its transmission or storage.
MD5 generated Checksum for a string is unique. And it will always give same checksum value as long as string does not change. Now selenium requests page we can use get_html_source to get back entire html source as a string. Then we can calculate checksums and we store it as our "html data or test data" and proceed with test.
Next time we run test we again get checksum and compare with the (existing) checksum that was recorded earlier.
Now there will be 2 scenarios ==>
1. Checksum is identical to recorded one which means there is no change in UI
2. Checksum do not match indicating change in UI.
If scenario 2) exists, then we can stop testing that particular page and send a report to QA that UI has changed for that particular page!!! At this point individual QA developers can visually inspect changes and verify by running test script meant for that particular page from there own laptops.
This will ensure that any UI change is taken care of. Sometimes we may get false-positive changes, might be due to some text element or images which don't really affect our test scripts because none of form fields or link ids have changed. Hence local execution of the test by QA will be all that is needed to verify if the GUI has really changed to necessitate script changes or its a non-script breaking changes.
Furthermore --- checksum algorithm and parsing html source to traverse through DOM to find elements - update soon...
Firstly we need to understand what is Checksum. According to wikipedia:
A checksum or hash sum is a fixed-size datum computed from an arbitrary block of digital data for the purpose of detecting accidental errors that may have been introduced during its transmission or storage.
MD5 generated Checksum for a string is unique. And it will always give same checksum value as long as string does not change. Now selenium requests page we can use get_html_source to get back entire html source as a string. Then we can calculate checksums and we store it as our "html data or test data" and proceed with test.
Next time we run test we again get checksum and compare with the (existing) checksum that was recorded earlier.
Now there will be 2 scenarios ==>
1. Checksum is identical to recorded one which means there is no change in UI
2. Checksum do not match indicating change in UI.
If scenario 2) exists, then we can stop testing that particular page and send a report to QA that UI has changed for that particular page!!! At this point individual QA developers can visually inspect changes and verify by running test script meant for that particular page from there own laptops.
This will ensure that any UI change is taken care of. Sometimes we may get false-positive changes, might be due to some text element or images which don't really affect our test scripts because none of form fields or link ids have changed. Hence local execution of the test by QA will be all that is needed to verify if the GUI has really changed to necessitate script changes or its a non-script breaking changes.
Furthermore --- checksum algorithm and parsing html source to traverse through DOM to find elements - update soon...
Monday, March 29, 2010
Automated Production Testing - Why does it raises eyebrows!
Every company has different rules and revenue impacts about production environment changes depending users input stream and business model.
AdWords is one of the most complex project I have ever worked on. AdWords involves huge complex calculations and collections of data and stats. It has various salient features and has a very heavy duty traffic of zillions ..trillions end users. These zillions..trillions end users are expected to perform various combination of actions and transactions. Testing such an application is in itself a challenge. Above all, even thinking about automating such an application was definitely complex and challenging!!
Certain aspects to take into consideration for automated production testing:
AdWords is one of the most complex project I have ever worked on. AdWords involves huge complex calculations and collections of data and stats. It has various salient features and has a very heavy duty traffic of zillions ..trillions end users. These zillions..trillions end users are expected to perform various combination of actions and transactions. Testing such an application is in itself a challenge. Above all, even thinking about automating such an application was definitely complex and challenging!!
Certain aspects to take into consideration for automated production testing:
Sunday, March 21, 2010
JUnit
As requested posting a blog about Junit
What is Junit ?
Simple framework for writing and running automated tests. Includes useful abstractions for running tests including test cases, text fixtures and test suites.
package junit.samples;
import junit.frameworks.*;
import java.util.Vector;
import junit.extensions.*;
/**
* sample test for
*/
public class VectorTest extends TestCase {
protected Vector fEmpty;
protected Vector fFull;
public VectorTest(String name) {
super(name);
}
public static void main (String[] args) {
junit.textui.TestRunner.run (suite());
}
...
protected void setUp() {
fEmpty = newVector();
fFull = new Vector();
fFull.addElement(new Integer(1));
fFull.addElement(new Integer(2));
fFull.addElement(new Integer(3));
}
public static Test suite() {
return new TestSuite(VectorTest.class);
}
public void testCapacity() {
int size= fFull.size();
for (int i=0; i < 100; i++)
fFull.addElement(new Integer(i));
assertTrue(fFull.size() == 100+size);
}
public void testClone() {
Vector clone = (Vector)fFull.clone();
assertTrue(clone.size() == fFull.size());
assertTrue(clone.contains(new Integer(1)));
}
}
...
What is JUnitPerf ?
Collection of JUnit tests decorators used to measure the performance and scalability of functionality contained within existing JUnit tests. When ever performance and scalability requirements are critical, JUnit perf plays an pivotal role.
Supported JUnit test decorators:
Timed tests: Runs a test and measures elapsed time
Load tests: Runs a test with concurrent users and iterations
Threaded tests: Runs a test in separate thread
JUnitEE: This is an extension to Junit. It allows tests to be executed inside an application server. Hence tests run in production environment.
Code Coverage Tools:
Emma - I have used Emma as well as our own version of Clover in my previous company. One can find all information about Emma at emma.sourceforge.net
Clover is commercial, free to open source project. Here is an example image for a cal app:
What is Junit ?
Simple framework for writing and running automated tests. Includes useful abstractions for running tests including test cases, text fixtures and test suites.
package junit.samples;
import junit.frameworks.*;
import java.util.Vector;
import junit.extensions.*;
/**
* sample test for
java.util.Vector
*/
public class VectorTest extends TestCase {
protected Vector fEmpty;
protected Vector fFull;
public VectorTest(String name) {
super(name);
}
public static void main (String[] args) {
junit.textui.TestRunner.run (suite());
}
...
protected void setUp() {
fEmpty = newVector();
fFull = new Vector();
fFull.addElement(new Integer(1));
fFull.addElement(new Integer(2));
fFull.addElement(new Integer(3));
}
public static Test suite() {
return new TestSuite(VectorTest.class);
}
public void testCapacity() {
int size= fFull.size();
for (int i=0; i < 100; i++)
fFull.addElement(new Integer(i));
assertTrue(fFull.size() == 100+size);
}
public void testClone() {
Vector clone = (Vector)fFull.clone();
assertTrue(clone.size() == fFull.size());
assertTrue(clone.contains(new Integer(1)));
}
}
...
What is JUnitPerf ?
Collection of JUnit tests decorators used to measure the performance and scalability of functionality contained within existing JUnit tests. When ever performance and scalability requirements are critical, JUnit perf plays an pivotal role.
Supported JUnit test decorators:
Timed tests: Runs a test and measures elapsed time
Load tests: Runs a test with concurrent users and iterations
Threaded tests: Runs a test in separate thread
JUnitEE: This is an extension to Junit. It allows tests to be executed inside an application server. Hence tests run in production environment.
Code Coverage Tools:
Emma - I have used Emma as well as our own version of Clover in my previous company. One can find all information about Emma at emma.sourceforge.net
Clover is commercial, free to open source project. Here is an example image for a cal app:
Qualities of a good Engineering or Test Manager
I have been fortunate to be reporting to a quality Test managers in the past. Looking at my past experience as well as current experience of reporting to test manager or a director led me to write this blog:
According to me whether you are explicitly a test manager or QA manager at least you should have following qualities.
Basically it all can be divided in top 5 points:
Creativity:You can never solve a problem on the level on which it was created. Discovery of new ideas or concepts. A good manager should be able to welcome/encourage new ideas or concepts. Be able to discuss pros and cons of such new idea or concept. Say for example, exploratory testing by various stakeholders or integrating guiceberry with junit3 or use of testng instead of junit3.
Leadership Skills: Leadership, a critical management skill, is the ability to motivate a group of people toward a common goal. These items will help you develop your skills as a leader.
Organization Skills:Practicing good organizational skills helps you to be prepared for your day-to-day responsibilities. Organizing your home, school or office will help you to work more efficiently, in whatever tasks you wish to accomplish.
Knowledge: Having domain expertise of the product or project is as important as being skill-full about the technologies or tools used - whether its a bugs tool or test case management tool. A good test manager will always be aware and be proactive about learning new technologies that are being used within his organization. For example test case management tool or bugs tool. Its essential to have a thourough knowledge about such tools which are used in day to day activities by entire QA organization. In terms of finding metrics or planning upcoming release cycle, these both tools play key role in providing visualization of various metrics like bug count, bug history, trends and patterns - which are looked upon by various stakeholders.
Innovation, Motivation, Enthusiasm: Extremely important. A good test manager should be able to motivate various members within his organization either by appreciating there work or making them responsible to take over a challenging project, where team member not only get an opportunity to prove himself (visibility) but also gets an opportunity to learn something new.
In my past company I was involved in developing a SDK which can be used to develop dashboard(s) or gadgets to provide various metrics. It gave me an opportunity to prove myself, huge huge visibility, learn new techs like GWT, Gviz!!!!
Another aspect could be innovation! Being innovative, being a pioneer of say a process or a framework!! In my past company I was involved in help automating release process. Understanding release process not just related to my own project but also to learnt it across various projects within same organization and then gathering requirements from various teams, stakeholders, outlining in terms of priority, presenting to higher authorities. And then designing which tech or lang to used to build, what are commonalities across board etc. After that comes actual implementation.
Enthusiasm - Being enthu about work you are actually performing and also be able to create equal amount of enthusiasm across board withing team members is as critical as motivation. If you do not feel enthu about your work then its very hard to keep team motivated! Without the enthusiasm to support their activities, it is extremely doubtful that the QA and Testing function will be successful. Doubt and negativity will only reinforce a perception that the QA and testing activities are not as value-added as programming activities and are a drain on schedule and budget. Enthusiasm is rare, however. Most employees want to do a good job, but they feel under appreciated. Generally, bad management is blamed for unmotivated workers, but often, good management can still provide unenthusiastic workers. So, what's the secret?
If your own employees aren't acting motivated or aren't acting enthusiastic, then it's time to get your own "act" in gear. You can fire up your workforce in three acts:
Act enthusiastic. Act grateful. Act happy.
Psychologists tell us that the best way to change our feelings about what we're doing is to change the way we think of our feelings. The brain tells the body how to feel and the body acts accordingly. We can direct our own feelings and our outlook on life. Writing in Out of Work? Get Into Business!, I wrote about expectations and how they can change the outcome of future events
Team Member:
Working on teams can be rewarding, but at times it can be difficult and downright frustrating. If there are poor communicators on your team, you may often feel left in the dark, confused or misunderstood. To create a successful team, effective communication methods are necessary for both team members and leaders. To have an effective team or be able to build team spirit, following norms usually been followed or enforced by a good test or quality manager.
According to me whether you are explicitly a test manager or QA manager at least you should have following qualities.
- Having domain expertise of the product that you are managing
- Technical knowledge about the technology or tools being used in an organization they are managing - if not expertise but some sort of knowledge
- Ability to have an healthy/productive technical discussion with reporters
- Ability to provide career guidance, recognize skill set, assign appropriate role
- Test manager should not under estimate reporters or co-workers
- Should have execellent knowledge of software development process
- Should always promote a positive atmosphere in the team
- Must promote teamwork to increase productivity
- Must maintain enthusiasm of team
- Must have preventive approach to the problems
- Must be able to promote cooperation between software, test, and QA engineers
- Should have the ability to promote improvements in QA processes
- Should have people judgement skills for hiring and keeping skilled personnel
- Should be able to organize meetings and keep them focused
- Good communication skills to communicate well with technical & non-technical people, engineers, managers and as well as with customers.
- Ability to say ‘no’ to other leads / managers when quality is insufficient or QA processes are not being adhered.
Basically it all can be divided in top 5 points:
Creativity:You can never solve a problem on the level on which it was created. Discovery of new ideas or concepts. A good manager should be able to welcome/encourage new ideas or concepts. Be able to discuss pros and cons of such new idea or concept. Say for example, exploratory testing by various stakeholders or integrating guiceberry with junit3 or use of testng instead of junit3.
Leadership Skills: Leadership, a critical management skill, is the ability to motivate a group of people toward a common goal. These items will help you develop your skills as a leader.
- Talking out loud
- Having a positive attitude
- Able to be change the perspective
- Effective convincing skills to deal with various stakeholders
- Able to recognize skill sets and assigning tasks
Organization Skills:Practicing good organizational skills helps you to be prepared for your day-to-day responsibilities. Organizing your home, school or office will help you to work more efficiently, in whatever tasks you wish to accomplish.
- Significance: Good organizational skills are significant because they help you to function better in everyday activities, from getting dressed in the morning to remembering appointments and meeting deadlines.
- Function: Being organized helps you to know what is expected of each day and to be prepared to meet those expectations. For example, creating a list of things you need prior to going to the store will make you a more effective manager of both your time and your money.
- Considerations: Consider the importance of being organized if you are in school and have to be responsible for assignments, if you have to keep appointments for your job or if you are running a household.
- Warning:Avoid overwhelming yourself with maintaining organization. It is often easy to be just as overwhelmed as you try to keep up with your new skills, as it is to be unorganized and cluttered. Ease your way into new organizational habits.
- Benefits:Good organizational skills will help you to finish tasks you begin. Focusing on completing a goal in an organized manner will enable you to eliminate things that may otherwise cause a distraction.
Knowledge: Having domain expertise of the product or project is as important as being skill-full about the technologies or tools used - whether its a bugs tool or test case management tool. A good test manager will always be aware and be proactive about learning new technologies that are being used within his organization. For example test case management tool or bugs tool. Its essential to have a thourough knowledge about such tools which are used in day to day activities by entire QA organization. In terms of finding metrics or planning upcoming release cycle, these both tools play key role in providing visualization of various metrics like bug count, bug history, trends and patterns - which are looked upon by various stakeholders.
Innovation, Motivation, Enthusiasm: Extremely important. A good test manager should be able to motivate various members within his organization either by appreciating there work or making them responsible to take over a challenging project, where team member not only get an opportunity to prove himself (visibility) but also gets an opportunity to learn something new.
In my past company I was involved in developing a SDK which can be used to develop dashboard(s) or gadgets to provide various metrics. It gave me an opportunity to prove myself, huge huge visibility, learn new techs like GWT, Gviz!!!!
Another aspect could be innovation! Being innovative, being a pioneer of say a process or a framework!! In my past company I was involved in help automating release process. Understanding release process not just related to my own project but also to learnt it across various projects within same organization and then gathering requirements from various teams, stakeholders, outlining in terms of priority, presenting to higher authorities. And then designing which tech or lang to used to build, what are commonalities across board etc. After that comes actual implementation.
Enthusiasm - Being enthu about work you are actually performing and also be able to create equal amount of enthusiasm across board withing team members is as critical as motivation. If you do not feel enthu about your work then its very hard to keep team motivated! Without the enthusiasm to support their activities, it is extremely doubtful that the QA and Testing function will be successful. Doubt and negativity will only reinforce a perception that the QA and testing activities are not as value-added as programming activities and are a drain on schedule and budget. Enthusiasm is rare, however. Most employees want to do a good job, but they feel under appreciated. Generally, bad management is blamed for unmotivated workers, but often, good management can still provide unenthusiastic workers. So, what's the secret?
If your own employees aren't acting motivated or aren't acting enthusiastic, then it's time to get your own "act" in gear. You can fire up your workforce in three acts:
Act enthusiastic. Act grateful. Act happy.
Psychologists tell us that the best way to change our feelings about what we're doing is to change the way we think of our feelings. The brain tells the body how to feel and the body acts accordingly. We can direct our own feelings and our outlook on life. Writing in Out of Work? Get Into Business!, I wrote about expectations and how they can change the outcome of future events
Team Member:
Working on teams can be rewarding, but at times it can be difficult and downright frustrating. If there are poor communicators on your team, you may often feel left in the dark, confused or misunderstood. To create a successful team, effective communication methods are necessary for both team members and leaders. To have an effective team or be able to build team spirit, following norms usually been followed or enforced by a good test or quality manager.
- Team members as coworkers: all team members are equal; every team member's opinion will be thoughtfully considered; each team member will keep all commitments by the agreed upon due date; each team member agrees to constantly assess whether team members are honoring their commitment to the team norms.
- Team member communication: team members will speak respectfully to each other; will not talk down to each other; will positively recognize and thank each other for team contributions.
- Team member interaction in meetings: team members will listen without interrupting; hold no side or competing conversations; follow the rules for effective meetings; attend the meeting on time; always work from an agenda; minutes will be recorded at each meeting; end meetings on time.
- Team organization and function: leadership will rotate monthly; the team management sponsor will attend the meeting, at least, monthly.
- Team communication with other employees including managers: team members will make certain they have agreement on what and when to communicate; complaints about team members will be addressed first in the team.
- Team problem solving, conflict resolution, and decision making: team members will make decisions by consensus, but majority will rule if timely consensus is not reached; conflicts will be resolved directly with the persons in conflict
Thursday, February 25, 2010
Watij - Web App Testing In Java
Watij: is a pure Java api created to allow for the automation of web applications through a real browser. It performs the same actions you would in a browser: filling out forms, navigating, clicking random stuff, and verifying results.
Did I mentioned, it was inspired by Watir - Web App testing in Ruby
Basic terminology that Watij follows is:
Container: Browser is a container.
Document: The webpage you view
To open new instance of IE, just see this www.watij.com or
IE ie = new IE();
ie.start();
To open new url:
Define URL = www.google.com
IE ie = new IE();
ie.start(URL);
To close instance:
ie.close();
You can find API: http://watij.sourceforge.net/docs/api/index.html?watij/IE.html
How to find elements using watij ?
Elements can be found in watij using many approaches:
1. Symbols: name, url, id, href, value, caption, title, alt, src, action, method, text, xpath, tag like:
ie.textField(id,“SOME_ID”);
2. Finders: exist for each symbol and also allow for more flexibility in defining ways to find elements like:
ie.htmlElement(attribute(“myattr1”,”attribute1”));
3. Xpath: Watij provides support for using XPath as a Symbol or a Finder. Watij uses the local copy of the document for faster parsing like:
ie.button(xpath, "//INPUT[@value='Hate Me']”);
4. Reg Ex: Watij also provides support for finding elements using regular expressions like:
ie.button(value, “/Hate Me/”);
Watij provides direct support for Javascript alerts, confirm pop ups, file download dialogs and prompt dialogs.
Here is an example of JS alert:
AlertDialog alertDialog = ie.alertDialog();
alertDialog.ok();
While automation there are a few things that everyone should keep in mind:
1.Ensure that you are following good design principles.
2.Try to model the application under test using a layer of abstraction.
3. Your tests should be readable by your customer.
The drawback is it only supports Windows and IE..hmmm
Did I mentioned, it was inspired by Watir - Web App testing in Ruby
Basic terminology that Watij follows is:
Container: Browser is a container.
Document: The webpage you view
To open new instance of IE, just see this www.watij.com or
IE ie = new IE();
ie.start();
To open new url:
Define URL = www.google.com
IE ie = new IE();
ie.start(URL);
To close instance:
ie.close();
You can find API: http://watij.sourceforge.net/docs/api/index.html?watij/IE.html
How to find elements using watij ?
Elements can be found in watij using many approaches:
1. Symbols: name, url, id, href, value, caption, title, alt, src, action, method, text, xpath, tag like:
ie.textField(id,“SOME_ID”);
2. Finders: exist for each symbol and also allow for more flexibility in defining ways to find elements like:
ie.htmlElement(attribute(“myattr1”,”attribute1”));
3. Xpath: Watij provides support for using XPath as a Symbol or a Finder. Watij uses the local copy of the document for faster parsing like:
ie.button(xpath, "//INPUT[@value='Hate Me']”);
4. Reg Ex: Watij also provides support for finding elements using regular expressions like:
ie.button(value, “/Hate Me/”);
Watij provides direct support for Javascript alerts, confirm pop ups, file download dialogs and prompt dialogs.
Here is an example of JS alert:
AlertDialog alertDialog = ie.alertDialog();
alertDialog.ok();
While automation there are a few things that everyone should keep in mind:
1.Ensure that you are following good design principles.
2.Try to model the application under test using a layer of abstraction.
3. Your tests should be readable by your customer.
The drawback is it only supports Windows and IE..hmmm
Thursday, February 11, 2010
Importance of pre-production like environment
Pre-production environment plays pivotal role in defining test completion criteria. System Performance and System Readiness testing rely on a stable system like Production - called Pre-prod environment. These tests are final preparation for the new system and will dictate whether the Production environment is ready for actual production processing. In terms of completion criteria, both phases are all or nothing. This means, in both phases, tests either pass or fail as a whole based on pre-determined criteria from Business Users, Legacy Owners, and Process Owners.
The precautions an organization should take place:
Since these environment is very close to real production environment, tons of weired behavior of application or product can be detected early on in release cycle in help avoiding last minutes or production emergencies.
However, one should not perform entire testing on these environments. Say a day or 2 days execution of various tests is good enough!
The precautions an organization should take place:
- Entire infrastructure or architecture should be as close as production
- Various kinds of testing to be preformed
- Accounts to be used against these enviornments
- Revenue impacts
- Automated testing if any, which test scenarios to be executed
Since these environment is very close to real production environment, tons of weired behavior of application or product can be detected early on in release cycle in help avoiding last minutes or production emergencies.
However, one should not perform entire testing on these environments. Say a day or 2 days execution of various tests is good enough!
Monday, February 1, 2010
Dependency Injection in Ruby
I had an opportunity to use DI in one of my past company projects. Since I have made a switch to Ruby at work, just wanted explore DI in ruby world.
Before that I should mention that Ruby is focus on simplicity and productivity. Syntax in ruby is elegant and easy to read/write.
Initially I was under impression that DI equals Spring, but that's not entirely true. In simple terms, DI contributes to mitigate the proliferation of dependencies. A good example is use of factory class is most common way to implement DI.
In ruby, DI concepts to creation of objects and wiring them...
Example: TBAdded later...
Before that I should mention that Ruby is focus on simplicity and productivity. Syntax in ruby is elegant and easy to read/write.
Initially I was under impression that DI equals Spring, but that's not entirely true. In simple terms, DI contributes to mitigate the proliferation of dependencies. A good example is use of factory class is most common way to implement DI.
In ruby, DI concepts to creation of objects and wiring them...
Example: TBAdded later...
Subscribe to:
Posts (Atom)