Skip to main content

No project description provided

Project description

jupyter_kernel_test is a tool for testing Jupyter kernels. It tests kernels for successful code execution and conformance with the Jupyter Messaging Protocol (currently 5.0).

Install

Install it with pip (python3.4 or greater required):

pip3 install jupyter_kernel_test

Usage

To use it, you need to write a (python) unittest file containing code samples in the relevant language which test various parts of the messaging protocol. A short example is given below, and you can also refer to the test_ipykernel.py and test_irkernel.py files for complete examples.

Some parts of the messaging protocol are relevant only to the browser-based notebook (rich display) or console interfaces (code completeness, history searching). Only parts of the spec for which you provide code samples are tested.

Run this file directly using python, or use nosetests or py.test to find and run it.

Example

import unittest
import jupyter_kernel_test


class MyKernelTests(jupyter_kernel_test.KernelTests):
    # Required --------------------------------------

    # The name identifying an installed kernel to run the tests against
    kernel_name = "mykernel"

    # language_info.name in a kernel_info_reply should match this
    language_name = "mylanguage"

    # Optional --------------------------------------

    # Code in the kernel's language to write "hello, world" to stdout
    code_hello_world = "print 'hello, world'"

    # Pager: code that should display something (anything) in the pager
    code_page_something = "help(something)"

    # Samples of code which generate a result value (ie, some text
    # displayed as Out[n])
    code_execute_result = [{"code": "6*7", "result": "42"}]

    # Samples of code which should generate a rich display output, and
    # the expected MIME type
    code_display_data = [{"code": "show_image()", "mime": "image/png"}]

    # You can also write extra tests. We recommend putting your kernel name
    # in the method name, to avoid clashing with any tests that
    # jupyter_kernel_test adds in the future.
    def test_mykernel_stderr(self):
        self.flush_channels()
        reply, output_msgs = self.execute_helper(code='print_err "oops"')
        self.assertEqual(output_msgs[0]["header"]["msg_type"], "stream")
        self.assertEqual(output_msgs[0]["content"]["name"], "stderr")
        self.assertEqual(output_msgs[0]["content"]["text"], "oops\n")


if __name__ == "__main__":
    unittest.main()

Coverage

The following aspects of the messaging protocol are not explicitly tested:

  • Widget comms: comm_open, comm_msg, comm_close

  • stdin: input_request, input_reply

  • display_data metadata

  • Shutdown/restart: shutdown_request, shutdown_reply

  • History: not all option combinations covered

  • Inspection: multiple levels

  • Execution payloads (deprecated but still used): payloads load, edit, ask_exit

  • User expressions

  • Execution: combinations of silent, store_history and stop_on_error

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jupyter_kernel_test-0.7.0.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

jupyter_kernel_test-0.7.0-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

File details

Details for the file jupyter_kernel_test-0.7.0.tar.gz.

File metadata

  • Download URL: jupyter_kernel_test-0.7.0.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.11.8

File hashes

Hashes for jupyter_kernel_test-0.7.0.tar.gz
Algorithm Hash digest
SHA256 078b6fe7f770dd164f9549bdd7a355663225a3ff9b0f7575ad546d27239ec609
MD5 de3b92fb43da56c886fe5e88fed6d440
BLAKE2b-256 b08600e0f5a663b10f40754ed7f3a9debb0ef3bc3f724cc32356b7b6bb4ca157

See more details on using hashes here.

File details

Details for the file jupyter_kernel_test-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyter_kernel_test-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2c60503b36cf0c58a7fb3b62e29254d2f2a9bd11c3fe634041e46f0a9b9eab98
MD5 c5c6c5e986e766cfecded7af0d7d1efe
BLAKE2b-256 7242d57a938cad4e99bb799f35105561959b0a0550c65fbc1ed671196e27f909

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page