CSE 7314/5314 (Fall 2016): Course Project

Prof. Jeff Tian (tian@lyle.smu.edu)

Assignment

Your project is a major part of your CSE 7314/5314. It will consist of the following parts or stages: Notice:

The details are given below.

Acceptable project types

There are two types of basic choices for your course project, one focusing on testing, and anther focusing on other QA techniques.
  1. An application of some specific testing techniques/models to some programs/products/applications/services you are developing/testing/maintaining/supporting/using/considering. For example, you may choose to construct control flow and data flow models to test a module you are developing at your work from a designer/developer's perspective, or to construct a finite state machine to capture the expected behavior of a software or application and testing it accordingly from a user's perspective, or augment your FSM with quantified usage information into a Markov chain operational profile (OP) to perform usage-based statistical testing from a collective users' perspective. Another example is the development, validation, and usage of an operational profile for a large software systems you are working on and collect testing data to quantify its reliability.

    It's generally a good idea to consider multiple (I'd say two as a minimum for an individual project) testing techniques and actually use a couple of them in your project to get a hands-on feeling of how different techniques and models work in practical applications.

    Pay special attention to the evaluation of your testing/analysis results. Be prepared to answer this type of questions:

    Your answer can be based on either the practical evidence (executing several types of testing cases and observing the results) or based on logical arguments (suitability of certain testing technique on certain types of products), or both.

  2. You may choose to focus on performing various other quality assurance activities and document the results, while performing limited/small-scale testing. Possibilities include comprehensive inspection, defect prevention and process improvement, formal verification, and fault tolerance. You may also collect inspection/testing/QA records for a product at your work, and construct quality models to analyze the results, to assess the effectiveness of your inspection/testing/QA techniques, or to identify high-defect modules for focused quality improvement actions.

    If you choose this second type of project, I still want you to perform at least some small scale/amount of testing because it is such an important part of our course. For the QA part, make sure you are focusing on quality that can be quantified and analyzed. For example, some defect analysis, both the root cause analysis type and statistical analysis, or even some classified defect data analysis using schemes such as ODC/af, and some reliability analysis would be appropriate. However, a process definition/improvement initiative with only a logical argument for its superiority is not suitable for this class.

    Again, the primary difference in the project requirements for undergraduate and graduate students is in the result analysis part, similar to that for testing-focused project discussed above.

Important: Regardless of the type of project you selected, you have to do something (testing, QA) specifically for this class. That is, a simple documentation of on-going testing/QA at work or someone else's work will not receive credit for this project assignment.

Where to Find Something to Test or to Perform QA on?

Project proposals

Your project proposal should be around 3-4 double spaced pages in length, and should include the following information: In case of a group project, please also pay attention to the following:

Please keep in mind that by the time you submit your project proposal, we have only covered less than half of the class material, although an overview of the whole course was given at the beginning of the semester. Therefore, you may make certain modifications to the things you propose, but the basic framework should be there in your proposal.

Once I have reviewed your proposal and provided my feedback, you need to address the issues I raised in your final project report. However, in most of the cases, you do NOT need to submit a revised proposal. In the rare case that your proposal is "unacceptable", I'll explicitly ask you to re-do/re-submit your proposal.

Project summary vs presentation for on-campus and distance students

All the graduate students are required to submit a project summary, in presentation slide format (2-5 slides), suitable for in-class presentation by the professor (or by the students), if you are not doing a full presentation (see below) in class. You summary should focus on the main results from your project for us to get the basic picture. Here is a template for your project summary.

You may choose to do a (full) project presentation. In that case, you don't need to submit the project summary. Each presentation should last about 10-15 minutes, with appropriate numbers of slides. You need to highlight the problem/solution-strategy/results/analysis for us to get the basic picture, but not necessarily all the details, which would require much more than 15 minutes. One common mistake in the past is too much background information but not enough testing/QA-specific technical information. Also, avoid detailed description of the test cases and activities performed.

As I stated earlier, this part is optional for undergraduate students.

Project report

The project report should be treated as a term paper, around 15 double-spaced pages in length, but no longer than 20 pages, for graduate students. The report should clearly and comprehensively states the background, problem, strategy, activities, results, result analysis, lessons learned, followup actions, and a high level summary (and an abstract at the beginning). Additional material, such as graphs, models, test cases, etc. produced, information sources and raw data, customer surveys, etc., can be included in the appendix and clearly marked as such (so it will not be counted towards your 20 page quota).

For undergraduate students, you report should be similar, except the analysis part (see information in the "Proposal" section above). As a result, your report is expected to be around 10-12 pages. But, if you choose to, you can follow the instruction for graduate students as well.

The format/sequence should be similar to what I listed for the project proposal, but, of course, with more results (what you did and discovered, not just what you proposed to do).

If you are not familiar with technical reports or papers, please consult technical/professional journals and conferences proceedings published by ACM, IEEE (particularly its Computer Society), and/or other reputable organizations.

Several common mistakes to avoid:


Prepared by Jeff Tian (tian@lyle.smu.edu).
Initially posted: Aug. 25, 2016. Last update: Aug. 25, 2016.

Back to CSE 5314/7314 Webpage