QA:Testcase Retrace Server CLI
From FedoraProject
Contents |
Description
This test case tests the Retrace Server's command line interface.
- There are two Retrace Server instances running in the Fedora infrastructure at the moment:
retrace.fedoraproject.organdretrace02.fedoraproject.org.abrt-retrace-clientdefaults to the first one, which only supports Fedora 15 and will be soon replaced by theretrace02machine. For testing purposes theretrace02server needs to be used. - You need to use insecure mode (the retrace process is not stopped on certificate error), thus it is not a good idea to use coredumps that may contain sensitive data.
- You need a readable and writable crash directory, that's why you must run the application under root if you want to use
/var/spool/ccpp-*crashes.$HOME/.abrt/spool/ccpp-*should work fine even without root privileges.
Setup
- Make sure you have ABRT crashes caught by CCpp (crashes in C and C++ applications) that need retrace (i.e. you haven't already retrieved the necessary debuginfo packages and generated the full backtrace) available. If you do not have any, run a C or C++ application and crash it using
kill -SIGSEGV (pid)orpkill -SIGSEGV (processname) - The crash reports will be under
/var/spool/abrt; you can identify them by the date and time
How to test
- Run
abrt-retrace-client create -d /path/ABRT_crash_directory - Run
abrt-retrace-client create --url retrace02.fedoraproject.org -d /path/ABRT_crash_directory - Run
abrt-retrace-client create --url retrace02.fedoraproject.org -k -d /path/ABRT_crash_directory, the-koption disables HTTPS certificate check - Run
abrt-retrace-client status --url retrace02.fedoraproject.org -k -t task_id -p task_passwordwith task_id and task_password obtained fromcreateaction - Run
abrt-retrace-client status --url retrace02.fedoraproject.org -k -t task_id -p task_passwordwith a wrong combination of task_id and task_password - Run
abrt-retrace-client log --url retrace02.fedoraproject.org -k -t task_id -p task_passwordwhile the job is stillPENDING - Run
abrt-retrace-client log --url retrace02.fedoraproject.org -k -t task_id -p task_passwordafter the job is finished (by success or failure) - Run
abrt-retrace-client backtrace --url retrace02.fedoraproject.org -k -t task_id -p task_passwordafter the job is finished successfully - Run
abrt-retrace-client backtrace --url retrace02.fedoraproject.org -k -t task_id -p task_passwordafter the job is finished by failure - Run
abrt-retrace-client batch --url retrace02.fedoraproject.org -k -d /path/ABRT_crash_directory - Run
abrt-retrace-client create --url retrace02.fedoraproject.org -k -d /path/ABRT_crash_directory, replacing coredump, executable or package file by some random content - Try to upload a larger crash (eg. kill JVM).
- Try to replace coderump, executable or package file by some special file (device, symlink)
Expected Results
- The process should fail because F16 is not supported by the default server
- The process should fail because of certificate hostname mismatch
- The job should be started, task_id and task_password returned on stdout
- One of the values
PENDING,FINISHED_SUCCESS,FINISHED_FAILUREshould be returned on stdout together with a more detailed description - HTTP
404 Not Foundor403 Forbiddenerror code should be returned depending on whether task with task_id exists or not. Should be the same withlogandbacktraceactions - HTTP
404 Not Founderror code should be returned. Should be the same withbacktraceaction - Plaintext log should be returned on stdout
- Plaintext backtrace should be returned on stdout
- HTTP
404 Not Founderror code should be returned - All actions should happen at once - create, periodically ask for status, download log (print to stdout) / backtrace (save into crash directory) depending on whether the result was successful or not
- The task should finish by failure
- If the upload size is larger than 8 MB, you should be prompted to confirm
- The request should be denied