summaryrefslogtreecommitdiff
path: root/Omni/Bild/Example.py
diff options
context:
space:
mode:
authorBen Sima <ben@bsima.me>2024-11-15 14:55:37 -0500
committerBen Sima <ben@bsima.me>2024-12-21 10:06:49 -0500
commit6513755670892983db88a6633b8c1ea6019c03d1 (patch)
tree44e9eccdb7a3a74ab7e96a8fee7572dd6a78dc73 /Omni/Bild/Example.py
parentae7b7e0186b5f2e0dcd4d5fac0a71fa264caedc2 (diff)
Re-namespace some stuff to Omni
I was getting confused about what is a product and what is internal infrastructure; I think it is good to keep those things separate. So I moved a bunch of stuff to an Omni namespace, actually most stuff went there. Only things that are explicitly external products are still in the Biz namespace.
Diffstat (limited to 'Omni/Bild/Example.py')
-rw-r--r--Omni/Bild/Example.py45
1 files changed, 45 insertions, 0 deletions
diff --git a/Omni/Bild/Example.py b/Omni/Bild/Example.py
new file mode 100644
index 0000000..e5766ba
--- /dev/null
+++ b/Omni/Bild/Example.py
@@ -0,0 +1,45 @@
+"""
+Test that bild can build Python stuff.
+
+Example Python file that also serves as a test case for bild.
+"""
+
+# : out example
+# : dep cryptography
+import cryptography.fernet
+import sys
+
+
+def cryptic_hello(name: str) -> str:
+ """
+ Encrypt and decrypt `name`.
+
+ Example taken from `cryptography` docs.
+
+ Raises:
+ ValueError: if decryption fails
+ """
+ key = cryptography.fernet.Fernet.generate_key()
+ f = cryptography.fernet.Fernet(key)
+ token = f.encrypt(hello(name).encode("utf-8"))
+ ret = f.decrypt(token).decode("utf-8")
+ if ret != hello(name):
+ msg = "en/decryption failed!"
+ raise ValueError(msg)
+ return ret
+
+
+def hello(name: str) -> str:
+ """Say hello."""
+ return f"Hello {name}"
+
+
+def main() -> None:
+ """Entrypoint."""
+ if "test" in sys.argv:
+ sys.stdout.write("testing success")
+ sys.stdout.write(cryptic_hello("world"))
+
+
+if __name__ == "__main__":
+ main()