Project Date
demo 08 Apr 2022, 10:38

Tag Report

Steps Scenarios Features
Tag Passed Failed Skipped Pending Undefined Total Passed Failed Total Duration Status
@teacher 390 0 0 0 0 390 69 0 69 3.042 Passed
Tags: @teacher
0.107
Given path 'approve/'+application.id 0.000
When method PATCH 0.032
Given path 'application', 'finish/'+application.id 0.000
When method PATCH 0.074
Then status 200 0.000
Tags: @teacher
0.006
Given path 'finish/100' 0.000
When method PATCH 0.005
Then status 404 0.000
Tags: @teacher
0.007
Given path 'finish/'+application.id 0.000
When method PATCH 0.006
Then status 422 0.000
And match response == 'Application is not in state RUNNING or STOPPED' 0.000
Tags: @teacher
0.012
Given path 'deny/'+application.id 0.000
When method PATCH 0.003
Given path 'application', 'finish/'+application.id 0.000
When method PATCH 0.008
Then status 422 0.000
And match response == 'Application is not in state RUNNING or STOPPED' 0.000
Tags: @teacher
0.088
Given path 'approve/'+application.id 0.000
When method PATCH 0.028
Given path 'application','finish/'+application.id 0.000
When method PATCH 0.038
Given path 'application', 'finish/'+application.id 0.000
When method PATCH 0.020
Then status 422 0.000
And match response == 'Application is not in state RUNNING or STOPPED' 0.000
Tags: @teacher
0.195
Given path 'approve/'+application.id 0.000
When method PATCH 0.031
Given path 'application','stop/'+application.id 0.000
When method PATCH 0.079
Given path 'application', 'finish/'+application.id 0.000
When method PATCH 0.083
Then status 200 0.000
Tags: @teacher
0.016
When method GET 0.016
Then status 200 0.000
And assert response.length == 1 0.000
Tags: @teacher
0.028
Given path 'approve/'+application.id 0.000
When method PATCH 0.028
Then status 200 0.000
Tags: @teacher
0.006
Given path 'approve/100' 0.000
When method PATCH 0.006
Then status 404 0.000
Tags: @teacher
0.038
Given path 'deny/'+application.id 0.000
When method PATCH 0.019
Given path 'application', 'approve/'+application.id 0.001
When method PATCH 0.017
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.000
Tags: @teacher
0.058
Given path 'approve/'+application.id 0.000
When method PATCH 0.048
Given path 'application', 'approve/'+application.id 0.000
When method PATCH 0.009
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.000
Tags: @teacher
0.250
Given path 'approve/'+application.id 0.000
When method PATCH 0.057
Given path 'application','stop/'+application.id 0.001
When method PATCH 0.147
Given path 'application', 'approve/'+application.id 0.001
When method PATCH 0.041
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.001
Tags: @teacher
0.076
Given path 'approve/'+application.id 0.000
When method PATCH 0.033
Given path 'application', 'finish/'+application.id 0.000
When method PATCH 0.032
Given path 'application', 'approve/'+application.id 0.000
When method PATCH 0.008
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.000
Tags: @teacher
0.040
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina"
  ]
}
When method PUT 0.026
Then status 204 0.000
And path 'beeyond' 0.000
When method GET 0.010
Then status 200 0.000
And match response.namespace == 'beeyond' 0.001
And match response.users == '#[1]' 0.002
Tags: @teacher
0.022
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "moritz"
  ]
}
When method PUT 0.013
Then status 204 0.000
And path 'beeyond' 0.000
When method GET 0.007
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[2]' 0.001
Tags: @teacher
0.034
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "moritz",
    "marc"
  ]
}
When method PUT 0.024
Then status 204 0.000
And path 'beeyond' 0.000
When method GET 0.008
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[3]' 0.001
Tags: @teacher
0.012
Given request 0.000
{
  "namespace": "bééyond",
  "users": [
    "emina",
    "moritz"
  ]
}
When method PUT 0.012
Then status 422 0.000
Tags: @teacher
0.034
* def generateString = read('classpath:string-generator.js') 0.002
Given request 0.011
{
  "namespace": #(generateString()),
  "users": [
    "emina",
    "moritz"
  ]
}
When method PUT 0.018
Then status 422 0.000
And match response[0].message == 'This field needs to be between 1 and 253 characters' 0.002
Tags: @teacher
0.010
Given request 0.000
{
  "namespace": "marc",
  "users": [
    "emina",
    "moritz"
  ]
}
When method PUT 0.009
Then status 422 0.000
And match response[0].message == 'Not a valid namespace name' 0.000
Tags: @teacher
0.011
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
     "test"
  ]
}
When method PUT 0.010
Then status 422 0.000
And match response[0].message == 'User with name [test] does not exist' 0.000
Tags: @teacher
0.010
Given request 0.000
{
  "namespace": "emina",
  "users": [
    "emina"
  ]
}
When method PUT 0.009
Then status 422 0.000
And match response[0].message == 'Not a valid namespace name' 0.000
Tags: @teacher
0.040
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina"
  ]
}
When method PUT 0.011
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "marc"
  ]
}
When method PUT 0.020
And path 'beeyond' 0.000
When method GET 0.007
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[2]' 0.000
Tags: @teacher
0.042
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "marc"
  ]
}
When method PUT 0.020
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "marc"
  ]
}
When method PUT 0.011
And path 'beeyond' 0.000
When method GET 0.009
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[2]' 0.000
Tags: @teacher
0.023
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "emina"
  ]
}
When method PUT 0.014
And path 'beeyond' 0.000
When method GET 0.007
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[1]' 0.000
Tags: @teacher
0.011
Given request 0.000
{
  "namespace": "emina",
  "users": [
    "emina",
    "emina"
  ]
}
When method PUT 0.011
Then status 422 0.000
And match response[0].message == 'Not a valid namespace name' 0.000
Tags: @teacher
0.042
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina"
  ]
}
When method PUT 0.019
Then status 204 0.000
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "marc"
  ]
}
When method PUT 0.010
Then status 204 0.000
And path 'beeyond' 0.000
When method GET 0.011
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[1]' 0.000
And match response.users[0].name == 'marc' 0.000
Tags: @teacher
0.031
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina"
  ]
}
When method PUT 0.011
Then status 204 0.000
Given request 0.000
{
  "namespace": "beeyond",
  "users": []
}
When method PUT 0.010
Then status 204 0.000
And path 'beeyond' 0.000
When method GET 0.007
Then status 200 0.000
And response.deleted == true 0.002
Tags: @teacher
0.031
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina"
  ]
}
When method PUT 0.012
Then status 204 0.000
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "marc"
  ]
}
When method PUT 0.009
Then status 204 0.000
And path 'beeyond' 0.000
When method GET 0.008
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[2]' 0.000
Tags: @teacher
0.048
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "emina",
    "marc"
  ]
}
When method PUT 0.013
Then status 204 0.000
Given request 0.000
{
  "namespace": "beeyond",
  "users": [
    "moritz",
    "stuetz"
  ]
}
When method PUT 0.025
Then status 204 0.000
And path 'beeyond' 0.000
When method GET 0.008
Then status 200 0.000
And match response.namespace == 'beeyond' 0.000
And match response.users == '#[2]' 0.000
And match response.users contains { 'name': 'moritz', 'id': #number } 0.000
And match response.users contains { 'name': 'stuetz', 'id': #number } 0.000
Tags: @teacher
0.019
When method GET 0.018
Then status 200 0.000
And assert response.length == 1 0.000
Tags: @teacher
0.022
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": "Port of your saver",
      "wildcard": "port",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.022
Then status 201 0.000
Tags: @teacher
0.015
Given request 0.000
{
  "name": "Nginx Deployment",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": "Port of your saver",
      "wildcard": "port",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.015
Then status 201 0.000
Tags: @teacher
0.012
Given request 0.000
{
  "description": "Static Webserver"
}
When method POST 0.011
Then status 422 0.000
And match response contains { message: 'This field cannot be empty', key: 'name', value: '' } 0.000
And match response contains { message: 'This field cannot be empty', key: 'content', value: '' } 0.000
Tags: @teacher
0.018
Given request 0.007
{
  "name": #(generateString()),
  "description": #(generateString()),
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": "Port of your saver",
      "wildcard": "port",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.011
Then status 422 0.000
And match response contains {message:'This field needs to be between 1 and 255 characters', key: 'name', value:'#ignore'} 0.000
And match response contains {message:'This field needs to be between 0 and 255 characters', key: 'description', value:'#ignore'} 0.000
Tags: @teacher
0.014
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    }
  ]
}
When method POST 0.014
Then status 422 0.000
And match response contains { message: 'Missing fields: [port], obsolete fields: []', value: '', key: '' } 0.000
Tags: @teacher
0.011
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": []
}
When method POST 0.011
Then status 422 0.000
And match response contains { message: 'Missing fields: [replica, port], obsolete fields: []', value: '', key: '' } 0.000
Tags: @teacher
0.017
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.017
Then status 422 0.000
And match response contains { message:'This field cannot be empty' ,value: '' ,key: 'wildcard' } 0.000
And match response contains { message:'This field cannot be empty' ,value: '' ,key: 'label' } 0.000
Tags: @teacher
0.019
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": "",
      "wildcard": "",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.019
Then status 422 0.000
And match response contains { message: 'This field cannot be empty' , value: '' , key: 'wildcard' } 0.000
And match response contains { message: 'This field cannot be empty' , value: '' , key: 'label' } 0.000
Tags: @teacher
0.020
Given request 0.008
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": #(generateString()),
      "wildcard": #(generateString()),
      "description": #(generateString())
    }
  ]
}
When method POST 0.011
Then status 422 0.000
And match response contains { message: 'This field needs to be between 0 and 255 characters', key:'label', value: '#ignore' } 0.000
And match response contains { message: 'This field needs to be between 0 and 255 characters', key:'description', value: '#ignore' } 0.000
And match response contains { message: 'This field needs to be between 0 and 255 characters', key:'wildcard', value: '#ignore' } 0.000
Tags: @teacher
0.015
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "wrong-wildcard",
      "description": "How many server should there be?"
    },
  ]
}
When method POST 0.015
Then status 422 0.000
And match response contains { message: 'Missing fields: [replica, port], obsolete fields: [wrong-wildcard]', value: '', key: '' } 0.000
Tags: @teacher
0.017
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "wrong-wildcard",
      "description": "How many server should there be?"
    },
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": "Port of your saver",
      "wildcard": "port",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.017
Then status 422 0.000
And match response contains { message: 'Missing fields: [], obsolete fields: [wrong-wildcard]', value: '', key: '' } 0.000
Tags: @teacher
0.020
Given request 0.000
{
  "id": 9999,
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": "Port of your saver",
      "wildcard": "port",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.019
Then status 201 0.000
Tags: @teacher
0.019
Given request 0.000
{
  "deleted": true,
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "label": "Port of your saver",
      "wildcard": "port",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.019
Then status 201 0.000
Tags: @teacher
0.017
Given request 0.000
{
  "name": "Nginx Deployment",
  "description": "Static Webserver",
  "content": "#(nginxDeployment)",
  "fields": [
    {
      "id": 9998,
      "label": "Server count",
      "wildcard": "replica",
      "description": "How many server should there be?"
    },
    {
      "id": 9999,
      "label": "Port of your saver",
      "wildcard": "port",
      "description": "This will be the port that will be exposed to the world"
    }
  ]
}
When method POST 0.017
Then status 201 0.000
Tags: @teacher
0.163
Given path 'approve/'+application.id 0.001
When method PATCH 0.048
Given path 'application', 'stop/'+application.id 0.001
When method PATCH 0.052
Given path 'application', 'start/'+application.id 0.000
When method PATCH 0.058
Then status 200 0.000
Tags: @teacher
0.011
Given path 'start/100' 0.000
When method PATCH 0.011
Then status 404 0.000
Tags: @teacher
0.013
Given path 'start/'+application.id 0.000
When method PATCH 0.011
Then status 422 0.000
And match response == 'Application is not in state STOPPED' 0.000
Tags: @teacher
0.019
Given path 'deny/'+application.id 0.001
When method PATCH 0.006
Given path 'application', 'start/'+application.id 0.000
When method PATCH 0.011
Then status 422 0.000
And match response == 'Application is not in state STOPPED' 0.000
Tags: @teacher
0.166
Given path 'approve/'+application.id 0.000
When method PATCH 0.063
Given path 'application','finish/'+application.id 0.001
When method PATCH 0.089
Given path 'application', 'start/'+application.id 0.000
When method PATCH 0.011
Then status 422 0.000
And match response == 'Application is not in state STOPPED' 0.000
Tags: @teacher
0.089
Given path 'approve/'+application.id 0.000
When method PATCH 0.041
Given path 'application', 'stop/'+application.id 0.000
When method PATCH 0.043
Then print karate.prevRequest.headers 0.004
10:38:07.638 [print] {
  "Authorization": [
    "Basic c3R1ZXR6OnBhc3N3b3Jk"
  ],
  "Host": [
    "localhost:8081"
  ],
  "Connection": [
    "Keep-Alive"
  ],
  "User-Agent": [
    "Apache-HttpClient/4.5.13 (Java/11.0.14)"
  ],
  "Accept-Encoding": [
    "gzip,deflate"
  ]
}
 
Then status 200 0.000
Tags: @teacher
0.006
Given path 'stop/100' 0.000
When method PATCH 0.005
Then status 404 0.000
Tags: @teacher
0.011
Given path 'stop/'+application.id 0.000
When method PATCH 0.009
Then status 422 0.000
And match response == 'Application is not in state RUNNING' 0.000
Tags: @teacher
0.015
Given path 'deny/'+application.id 0.000
When method PATCH 0.004
Given path 'application', 'stop/'+application.id 0.000
When method PATCH 0.011
Then status 422 0.000
And match response == 'Application is not in state RUNNING' 0.000
Tags: @teacher
0.139
Given path 'approve/'+application.id 0.000
When method PATCH 0.091
Given path 'application','finish/'+application.id 0.001
When method PATCH 0.036
Given path 'application', 'stop/'+application.id 0.000
When method PATCH 0.010
Then status 422 0.000
And match response == 'Application is not in state RUNNING' 0.000
Tags: @teacher
0.112
Given path 'approve/'+application.id 0.000
When method PATCH 0.036
Given path 'application','stop/'+application.id 0.000
When method PATCH 0.061
Given path 'application', 'stop/'+application.id 0.000
When method PATCH 0.013
Then status 422 0.000
And match response == 'Application is not in state RUNNING' 0.000
Tags: @teacher
0.014
Given path 'deny/'+application.id 0.000
When method PATCH 0.013
Then status 200 0.000
Tags: @teacher
0.011
Given path 'deny/100' 0.000
When method PATCH 0.011
Then status 404 0.000
Tags: @teacher
0.059
Given path 'approve/'+application.id 0.000
When method PATCH 0.044
Given path 'application', 'deny/'+application.id 0.001
When method PATCH 0.012
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.000
Tags: @teacher
0.033
Given path 'deny/'+application.id 0.000
When method PATCH 0.017
Given path 'application','deny/'+application.id 0.001
When method PATCH 0.013
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.000
Tags: @teacher
0.140
Given path 'approve/'+application.id 0.000
When method PATCH 0.038
Given path 'application','stop/'+application.id 0.001
When method PATCH 0.078
Given path 'application', 'deny/'+application.id 0.000
When method PATCH 0.021
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.000
Tags: @teacher
0.127
Given path 'approve/'+application.id 0.000
When method PATCH 0.034
Given path 'application', 'finish/'+application.id 0.000
When method PATCH 0.080
Given path 'application', 'deny/'+application.id 0.000
When method PATCH 0.011
Then status 422 0.000
And match response == 'Application is not in state PENDING' 0.000
Tags: @teacher
0.029
Given path template.id 0.000
When method DELETE 0.016
Then status 204 0.000
Given path template.id 0.000
When method GET 0.012
Then status 200 0.000
And match response.deleted == true 0.000
Tags: @teacher
0.007
Given path '1000' 0.000
When method DELETE 0.006
Then status 404 0.000
Tags: @teacher
0.022
Given path 'deny/'+application.id 0.000
When method PATCH 0.010
Given path 'application', 'request/'+application.id 0.000
When method PATCH 0.010
Then status 200 0.000
Tags: @teacher
0.006
Given path 'request/100' 0.000
When method PATCH 0.005
Then status 404 0.000
Tags: @teacher
0.008
Given path 'request/'+application.id 0.000
When method PATCH 0.007
Then status 422 0.000
And match response == 'Application is not in state DENIED' 0.000
Tags: @teacher
0.033
Given path 'approve/'+application.id 0.000
When method PATCH 0.025
Given path 'application', 'request/'+application.id 0.000
When method PATCH 0.007
Then status 422 0.000
And match response == 'Application is not in state DENIED' 0.000
Tags: @teacher
0.074
Given path 'approve/'+application.id 0.000
When method PATCH 0.031
Given path 'application','finish/'+application.id 0.000
When method PATCH 0.032
Given path 'application', 'request/'+application.id 0.000
When method PATCH 0.010
Then status 422 0.000
And match response == 'Application is not in state DENIED' 0.000
Tags: @teacher
0.116
Given path 'approve/'+application.id 0.000
When method PATCH 0.034
Given path 'application','stop/'+application.id 0.000
When method PATCH 0.072
Given path 'application', 'request/'+application.id 0.000
When method PATCH 0.008
Then status 422 0.000
And match response == 'Application is not in state DENIED' 0.000