COMP2017/9017: Systems Programming

Hello, if you have any need, please feel free to consult us, this is my wechat: wx91due

COMP2017/9017

Assignment 3

Due: 23:59 12 May 2024

Assignment 3 Tests 5%

You have now under-taken another role within the Byte-Tide Project. You will be in-charge of devel- oping testing methods and procedures for the new version fo ‘ByteTide‘.  However you may or may not have access to stable version of the build, so you will need to follow on with the specification and do your best to construct an ample set of test cases.

You have been directed to focus on testing the following components of the ‘ByteTide‘ project:

• Merkle Tree

• .bpkg file format

For each component, re-read the Assignment Specification and outline parts of the document that you believe will cause ‘issues‘ and provide a clear rationale behind them.

1    Testing Report

You will need to deliver a test procedures document that you will use and also inform the developer team about. For each test-case entry, make sure your document contains:

• An identifier for the test case

• Provide a brief description of the issue (guide: 20 to 50 words)

• Input and resources required

• Test script/method (how to execute the tests)

• The expected result

You are allowed to use generative AI or external resources to complete this assessment. However you must provide attribution and citations for all resources you have used for your test case.

Creating test cases and integration tests of the resulting file system. Prompts and their corresponding test cases and testing software must be reported. Testing software can be generated by AI.

Include the version and source of the generative AI used.  See the example markdown file in section 5.

All these fields must be present and accurate

1 # Author

2 # Date

3 # AI used (yes/no)

4 # AI link

5

6 # Test #1 Description

7 # Test #2 Description

8 ...

9 # Test #10 Description

10

11 # AI Prompt #1

12 # AI Generated #1

13 # AI Prompt #2

14 # AI Generated #2

15 ...

16 # AI Prompt #M

17 # AI Generated #M

18

19 # Instructions to run testing script

• AI used - yes with version, otherwise no

• AI link - what is the URL to access this service

• AI Prompt - what you entered (asked)

•  AI Generated - what was returned.  Please summarise in one line and place any data/code in files with a reference to them.

•  Instructions to run testing script - all steps required for a person to setup and run a single test, or all tests.

There may be any number of prompts used, multiple instances (conversations), please cite the URL.

2    Testing script

Write 10 testing scripts that will independently run and test an implementation of the Merkle tree and package loader functionality.

Your report must include a section on how to setup and run tests. You are to organise your tests such that an implementation of btide or package_main binaries can be dropped in and tested.  For examples, see 6

The test environment is an Ed Discussion workspace.  Linux  5.15.0-101-generic  x86_ 64 with GNU  bash,  version  5.2.26.  No additional packages can be downloaded by the tester. If programs/libraries are small enough and the total repository size is within the limit, they can be included within the submission.

Be careful regarding assumptions surrounding:

• absolute file paths

• permissions for read, write, execute

•  architecture dependent binary builds

• architecture dependent binary data (non-portable read and write from file)

• .gitignore to exclude necessary testing binaries or related files

• forgetting to add the necessary testing binaries or related files

• an external dependency can be built from source on Ed (check it!)

• available super user privileges (not available on Ed).

Be sure that the grader can execute your tests within an Ed workspace.  You can always test this yourself by following your own instructions in a new Ed workspace.

Getting started

There are a number of test cases available from the Assignment 3 already. You are encouraged to look at these for inspiration. Those test cases do not cover all functionality or scenarios.

Think about what kind of scenarios would likely confirm the correctness rather than a unit test.

You may use generative AI, online resources, or other persons to help explore scenarios with these problems. Remember, you must always cite the sources.

Marking

4.1 Deliverables

You will need to upload the following deliverables to the ‘Testing - Bytetide‘ lesson slide on Ed.

• 4 marks - test_report.md - Markdown Document with at least 10 test-case entries

•  1 mark - tests directory - Test scripts and resources required to execute them

Marks are awarded on the test description and their precision in identifying test cases. Consider what are you searching for, how can you describe the specific program state(s) that you want to test. From what is the initial state to the new state and your expectations.

4.2 Deductions

Deductions will apply if the report file format is not followed:

• any of the sections are missing

• the author is missing/invalid

•  the date is missing/invalid. Use Unix date time $  date

• the description is missing (automatic zero)

• the link is missing, or does not work

• the prompt is missing

• the generated output is missing in test directory

Deductions will apply if:

•  tests are replicated from the already given test cases

• repository size exceeds MB

•  failure to clean up system resources used by testing script (e.g. create but never remove named pipe)

Sample report

** Sample AI generated test case and code for Backgammon implemented in Swift **

# Author

Joe Bloggs

# Date

Mon 15 Jan 2024 11:03:41 AEDT

# AI used (yes/no)

yes. ChatGPT 3.5

# AI link

https://chat.openai.com

# Test 1 Description − Initial board state

I am testing if the board has been setup correctly.

The input to this state is the program starting and configuration is set to defaults. A user makes a

, → selection to play a new game and the board is printed on the screen.

I am going to check and count that the characters appear in the correct positions on the screen.

# Test 2 Description − Player move is correct

The player must be able to make a valid move. I want to see if the legal move is considered first legal (

, → because there are illegal moves) and then to see if the board state is updated to reflect the token

, → being moved.

The input state of the program for this test is not the initial state, rather it is looking at a halfway

, → completed game whereby there are illegal moves possible, but a legal move is made.

The expected outcome is that the move is permitted and the board state

# Test 3 Description − A player can bear off

There is a rule in Backgammon that describes this rule: (https://www.gnu.org/software/gnubg/manual/

, → html_node/Bearing−Off.html). I want to check when bearing off is available and if the

, → implementation presents that option to the player.

The input state of the program is when all 15 checkers have moved into their home board.

The expected outcome is that after a dice roll, the player is able to remove the checker (as an option).

# AI Prompt 1

https://chat.openai.com/share/5d65ddd7−3a97−48a1−b8c2−44d07162dfd4

Write three test cases for a backgammon program written in the Swift programming language. The test

, → cases are checking:

− if the board is setup correctly

− if a player move has been effected correctly

− if a player can bear off (https://www.gnu.org/software/gnubg/manual/html_node/Bearing−Off.html)

# AI Generated 1

Test Case: Check if the board is setup correctly

See data in file tests/board_state/data1.in

Test Case: Check if a player move has been effected correctly

See data in file tests/board_state/data2.in

Test Case: Check if a player can bear off

See data in file tests/board_state/data3.in

# AI Prompt 2

Write the testing code required to run these test cases

# AI Generated 2

See code in file tests/board_state/testcode_1.swift

See code in file tests/board_state/testcode_2.swift

See code in file tests/board_state/testcode_3.swift

# Instructions to run testing script

Compile all testing code beforehand

```bash

testNumber=1 # a number 1−3

swiftc src/*.swift tests/board_state/testcode_${testNumber}.swift −o test_binary

```

Run this by entering the folder tests/board_state

```bash

./run_test.sh ${testNumber}

```

Sample test directory structures

The following is a suggested directory structure. Each folder is categorised and binary files are sym- linked to a top level bin directory.

| --  bin

|        | --  btide

|        `--  package_main

| --  test_report.md

`--  tests

| --  chunk

|        | --  btide  ->  ../../bin/btide

|        | --  chunk_test4.in

|        | --  chunk_test4.out

|        | --  chunk_test5.in

|        | --  chunk_test6.out

|        | --  package_main  ->  ../../bin/package_main

|      `--  run_test.sh

...

| --  merkle_simple

|        | --  btide  ->  ../../bin/btide

|        | --  merk_test1.in

|        | --  merk_test1.out

|        | --  package_main  ->  ../../bin/package_main

|      `--  run_test.sh

| --  merkle_tricky

|        | --  btide  ->  ../../bin/btide

|        | --  merk_test3.in

|        | --  merk_test3.out

|        | --  package_main  ->  ../../bin/package_main

|      `--  run_test.sh

...

`--  package

| --  data8.bpkg

| --  outcome8.out

| --  data9.bpkg

| --  outcome9.out

| --  package_main  ->  ../../bin/package_main

`--  run_test.sh

Another suggested directory structure.  Each test is entirely self contained within the folder.  The binary is assumed to be in the directory.

| --  test_report.md

`--  tests

| --  test01

|        | --  btide

|        | --  merk_test1.in

|        | --  merk_test.out

|      `--  run_test.sh

...

| --  test03

|        | --  btide

|        | --  merk_test3.in

|        | --  merk_test.out

|      `--  run_test.sh

...

| --  test09

|        | --  btide

|        | --  data9.bpkg

|        | --  outcome9.out

|        | --  package_main

|      `--  run_test.sh

`--  test10

| --  btide

| --  data10.in

| --  outcome10.out

| --  package_main

`--  run_test.sh




发表评论

电子邮件地址不会被公开。 必填项已用*标注