That's *one* of the people you want testing
People who want to find errors will tend to look for the type of things programmers don't like worrying about, like validating all user input. Tedious be necessary. But a good programmer will eventually learn that it has to be done, if for no other reason than that the tester will catch it.
The ones you want are the "random strangeness" people. The ones who will do something completely unanticipated. The things that even an experienced tester would never imagine someone would try to do. The ones who are so thick they will continue to do things you've told them not to do. In other words, a user.
Which leads to another actual conversation I had, just last week.
There is a customer account configuration module. One of the options in it is a checkbox marked "Inactive". If this box is checked, the customer can still log on to the extranet to track the status of their live orders, but they can not place any new orders. Internal usres also can not place new orders for the customer on the intranet.
We have a request from accounting to add an option for "Do Not Invoice". This was driven from an incident where there was a legal action with one of our soon-to-be former customers. The billing person contacted all the field offices and told them they had 30 days to process any outstanding invoicing and submit it. A final bill would be submitted, and the customer would be inactivated. Thirty days later, the bill is submitted, and the customer is inactivated. Then a user notices an unreleased invoice and releases it. Billing catches it, but wants a way to prevent this problem.
So far it seems strightforward, yes? Well I asked a simple question. If we can't invoice the customer, we probably don't want to take any new orders for them. So should I automatically inactivate the customer if "Do Not Invoice" is checked?
No, says billing. Because their practice is to give 30 days notice before inactivating a customer. They want to give the field offices time to release invoicing before inactivation. I pointed out that "Inactive" never prevented invoicing, and no one has suggested that it should. So they can mark an account "Inactive", thus preventing new orders, as soon as we decide we're cutting them off. Then 30 days later we can mark the account "Do Not Invoice". No, says billing again. They have to give them time to release the invoices before inactivating the account.
I tried (again) to point out that "Inactive" does not mean that you can't release invoices. It only means don't place new orders. "But if they're inactive, we shouldn't place orders or do the work or bill them or anything!" Wait, now you're talking about halting Vendor Assignment on existing open orders. In other words, don't assign anyone to do the work on open orders if the customer account is inactivated. That's an operational question completely outside the billing person's area of authority or responsibility.
After 1/2-hour on the phone, I just could not get through to her that "Inactive" only only only ONLY means do not place new orders. It has NO FUCKING EFFECT WHATSOEVER ON PROCESSING OPEN ORDERS OR RELEASING INVOICING!
...
So we're going to add a checkbox for "Do Not Invoice". And the next time this happens, the billing person will call all the service centers and tell them that they have 30 days to release any pending invoices for the customer. Then she will go into the customer maintenance module, and check the "Inactive" and "Do Not Invoice" checkboxes.
===
Purveyor of Doc Hope's [link|http://DocHope.com|fresh-baked dog biscuits and pet treats].
[link|http://DocHope.com|http://DocHope.com]