aboutsummaryrefslogtreecommitdiffstats
path: root/doxygen/test_framework_doc.md
blob: 3da29bbf10508429bcdd356d893a0cd35f308273 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
Test Framework Documentation    {#test_framework_doc}
============================

PyDoc generated documentation for the "make test" framework is available for
the following releases:

- [Test framework documentation for VPP 18.10](https://docs.fd.io/vpp/18.10/vpp_make_test/html)
- [Test framework documentation for VPP 18.07](https://docs.fd.io/vpp/18.07/vpp_make_test/html)
- [Test framework documentation for VPP 18.04](https://docs.fd.io/vpp/18.04/vpp_make_test/html)
- [Test framework documentation for VPP 18.01](https://docs.fd.io/vpp/18.01/vpp_make_test/html)
- [Test framework documentation for VPP 17.10](https://docs.fd.io/vpp/17.10/vpp_make_test/html)
- [Test framework documentation for VPP 17.04](https://docs.fd.io/vpp/17.04/vpp_make_test/html)
- [Test framework documentation for VPP 17.01](https://docs.fd.io/vpp/17.01/vpp_make_test/html)
ense at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ ]] local vpp = require "vpp-lapi" local ffi = require "ffi" ffi.cdef([[ struct timespec { long tv_sec; /* seconds */ long tv_nsec; /* nanoseconds */ }; int clock_gettime(int clk_id, struct timespec *tp); ]]) local time_cache = ffi.new("struct timespec[1]") local time_cache_1 = time_cache[0] function get_ns() ffi.C.clock_gettime(0, time_cache) return time_cache_1.tv_nsec + 1000000000 * time_cache_1.tv_sec end function do_bench() local cycle_start = get_ns() local n_iterations = 10000 local count = 1 for i = 1,n_iterations do -- print(i) vpp:api_call("show_version") count = count + 1 -- print(i, "done") end cycle_end = get_ns() local tps = n_iterations*1000000000LL/(cycle_end - cycle_start) print (tostring(count) .. " iterations, average speed " .. tostring(tps) .. " per second") return tps end root_dir = "/home/ubuntu/vpp" pneum_path = root_dir .. "/build-root/install-vpp_debug-native/vpp-api/lib64/libpneum.so" vpp:init({ pneum_path = pneum_path }) vpp:json_api(root_dir .. "/build-root/install-vpp_debug-native/vpp/vpp-api/vpe.api.json") vpp:connect("lua-bench") local n_tests = 10 local tps_acc = 0LL for i=1,n_tests do tps_acc = tps_acc + do_bench() end print("Average tps across the tests: " .. tostring(tps_acc/n_tests)) vpp:disconnect()