From b979408c1a3c3d5308508c1eda84e761b687dfa4 Mon Sep 17 00:00:00 2001 From: Haris <4259838+Wulf@users.noreply.github.com> Date: Wed, 1 Nov 2023 21:01:03 -0400 Subject: [PATCH 1/2] Add simple compilation test --- .github/workflows/CI.yml | 1 + README.md | 11 +- examples/Cargo.lock | 647 +++++++++++++++++++++ examples/Cargo.toml | 2 + examples/test_all.sh | 18 + examples/todo/Cargo.toml | 21 + examples/todo/src/dsync.rs | 26 + examples/todo/src/example.rs | 10 + examples/todo/src/models/common.rs | 12 + examples/todo/src/models/mod.rs | 2 + examples/todo/src/models/todo/generated.rs | 79 +++ examples/todo/src/models/todo/mod.rs | 2 + examples/todo/src/schema.rs | 9 + 13 files changed, 838 insertions(+), 2 deletions(-) create mode 100644 examples/Cargo.lock create mode 100644 examples/Cargo.toml create mode 100755 examples/test_all.sh create mode 100644 examples/todo/Cargo.toml create mode 100644 examples/todo/src/dsync.rs create mode 100644 examples/todo/src/example.rs create mode 100644 examples/todo/src/models/common.rs create mode 100644 examples/todo/src/models/mod.rs create mode 100644 examples/todo/src/models/todo/generated.rs create mode 100644 examples/todo/src/models/todo/mod.rs create mode 100644 examples/todo/src/schema.rs diff --git a/.github/workflows/CI.yml b/.github/workflows/CI.yml index 985dd141..bdaea264 100644 --- a/.github/workflows/CI.yml +++ b/.github/workflows/CI.yml @@ -64,6 +64,7 @@ jobs: ~/.cargo key: ${{ runner.os }}-cargo-dev-${{ hashFiles('**/Cargo.lock') }} - run: bash test/test_all.sh + - run: bash examples/test_all.sh - run: git diff --exit-code --quiet || exit 1 # things that use the cargo-test cache diff --git a/README.md b/README.md index 43c4a28a..4405b0d7 100644 --- a/README.md +++ b/README.md @@ -139,8 +139,15 @@ Feel free to open tickets for support or feature requests. ## Development/Testing -Use `./test/test_all.sh` to run tests. -After running the test, there should be no unexpected changes to files in `./test` (use `git status` and `git diff` to see if there were any changes). +- **Testing codegen correctness** + + Use `./test/test_all.sh` to run tests. + After running the test, there should be no unexpected changes to files in `./test` (use `git status` and `git diff` to see if there were any changes). + +- **Testing codegen compilability** + + Currently, we compile the projects in the `examples/` directory. Those should still compile and run after any changes to the codebase. + ## License diff --git a/examples/Cargo.lock b/examples/Cargo.lock new file mode 100644 index 00000000..ac32941a --- /dev/null +++ b/examples/Cargo.lock @@ -0,0 +1,647 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "android-tzdata" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e999941b234f3131b00bc13c22d06e8c5ff726d1b6318ac7eb276997bbb4fef0" + +[[package]] +name = "android_system_properties" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "819e7219dbd41043ac279b19830f2efc897156490d7fd6ea916720117ee66311" +dependencies = [ + "libc", +] + +[[package]] +name = "anstream" +version = "0.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2ab91ebe16eb252986481c5b62f6098f3b698a45e34b5b98200cf20dd2484a44" +dependencies = [ + "anstyle", + "anstyle-parse", + "anstyle-query", + "anstyle-wincon", + "colorchoice", + "utf8parse", +] + +[[package]] +name = "anstyle" +version = "1.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7079075b41f533b8c61d2a4d073c4676e1f8b249ff94a393b0595db304e0dd87" + +[[package]] +name = "anstyle-parse" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "317b9a89c1868f5ea6ff1d9539a69f45dffc21ce321ac1fd1160dfa48c8e2140" +dependencies = [ + "utf8parse", +] + +[[package]] +name = "anstyle-query" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5ca11d4be1bab0c8bc8734a9aa7bf4ee8316d462a08c6ac5052f888fef5b494b" +dependencies = [ + "windows-sys", +] + +[[package]] +name = "anstyle-wincon" +version = "3.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f0699d10d2f4d628a98ee7b57b289abbc98ff3bad977cb3152709d4bf2330628" +dependencies = [ + "anstyle", + "windows-sys", +] + +[[package]] +name = "autocfg" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "bitflags" +version = "2.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "327762f6e5a765692301e5bb513e0d9fef63be86bbc14528052b1cd3e6f03e07" + +[[package]] +name = "bumpalo" +version = "3.14.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f30e7476521f6f8af1a1c4c0b8cc94f0bee37d91763d0ca2665f299b6cd8aec" + +[[package]] +name = "byteorder" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" + +[[package]] +name = "cc" +version = "1.0.83" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f1174fb0b6ec23863f8b971027804a42614e347eafb0a95bf0b12cdae21fc4d0" +dependencies = [ + "libc", +] + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "chrono" +version = "0.4.31" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f2c685bad3eb3d45a01354cedb7d5faa66194d1d58ba6e267a8de788f79db38" +dependencies = [ + "android-tzdata", + "iana-time-zone", + "js-sys", + "num-traits", + "wasm-bindgen", + "windows-targets", +] + +[[package]] +name = "clap" +version = "4.4.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac495e00dcec98c83465d5ad66c5c4fabd652fd6686e7c6269b117e729a6f17b" +dependencies = [ + "clap_builder", + "clap_derive", +] + +[[package]] +name = "clap_builder" +version = "4.4.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c77ed9a32a62e6ca27175d00d29d05ca32e396ea1eb5fb01d8256b669cec7663" +dependencies = [ + "anstream", + "anstyle", + "clap_lex", + "strsim", + "terminal_size", +] + +[[package]] +name = "clap_complete" +version = "4.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bffe91f06a11b4b9420f62103854e90867812cd5d01557f853c5ee8e791b12ae" +dependencies = [ + "clap", +] + +[[package]] +name = "clap_derive" +version = "4.4.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cf9804afaaf59a91e75b022a30fb7229a7901f60c755489cc61c9b423b836442" +dependencies = [ + "heck", + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "clap_lex" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "702fc72eb24e5a1e48ce58027a675bc24edd52096d5397d4aea7c6dd9eca0bd1" + +[[package]] +name = "colorchoice" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "acbf1af155f9b9ef647e42cdc158db4b64a1b61f743629225fde6f3e0be2a7c7" + +[[package]] +name = "core-foundation-sys" +version = "0.8.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e496a50fda8aacccc86d7529e2c1e0892dbd0f898a6b5645b5561b89c3210efa" + +[[package]] +name = "diesel" +version = "2.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2268a214a6f118fce1838edba3d1561cf0e78d8de785475957a580a7f8c69d33" +dependencies = [ + "bitflags 2.4.1", + "byteorder", + "chrono", + "diesel_derives", + "itoa", + "pq-sys", + "r2d2", +] + +[[package]] +name = "diesel_derives" +version = "2.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ef8337737574f55a468005a83499da720f20c65586241ffea339db9ecdfd2b44" +dependencies = [ + "diesel_table_macro_syntax", + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "diesel_table_macro_syntax" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fc5557efc453706fed5e4fa85006fe9817c224c3f480a34c7e5959fd700921c5" +dependencies = [ + "syn", +] + +[[package]] +name = "dsync" +version = "0.0.17-beta" +dependencies = [ + "clap", + "clap_complete", + "heck", + "indoc", + "proc-macro2", + "syn", + "thiserror", +] + +[[package]] +name = "errno" +version = "0.3.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac3e13f66a2f95e32a39eaa81f6b95d42878ca0e1db0c7543723dfe12557e860" +dependencies = [ + "libc", + "windows-sys", +] + +[[package]] +name = "heck" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" + +[[package]] +name = "iana-time-zone" +version = "0.1.58" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8326b86b6cff230b97d0d312a6c40a60726df3332e721f72a1b035f451663b20" +dependencies = [ + "android_system_properties", + "core-foundation-sys", + "iana-time-zone-haiku", + "js-sys", + "wasm-bindgen", + "windows-core", +] + +[[package]] +name = "iana-time-zone-haiku" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f31827a206f56af32e590ba56d5d2d085f558508192593743f16b2306495269f" +dependencies = [ + "cc", +] + +[[package]] +name = "indoc" +version = "2.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e186cfbae8084e513daff4240b4797e342f988cecda4fb6c939150f96315fd8" + +[[package]] +name = "itoa" +version = "1.0.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" + +[[package]] +name = "js-sys" +version = "0.3.65" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "54c0c35952f67de54bb584e9fd912b3023117cbafc0a77d8f3dee1fb5f572fe8" +dependencies = [ + "wasm-bindgen", +] + +[[package]] +name = "libc" +version = "0.2.149" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a08173bc88b7955d1b3145aa561539096c421ac8debde8cbc3612ec635fee29b" + +[[package]] +name = "linux-raw-sys" +version = "0.4.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "da2479e8c062e40bf0066ffa0bc823de0a9368974af99c9f6df941d2c231e03f" + +[[package]] +name = "lock_api" +version = "0.4.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c168f8615b12bc01f9c17e2eb0cc07dcae1940121185446edc3744920e8ef45" +dependencies = [ + "autocfg", + "scopeguard", +] + +[[package]] +name = "log" +version = "0.4.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b5e6163cb8c49088c2c36f57875e58ccd8c87c7427f7fbd50ea6710b2f3f2e8f" + +[[package]] +name = "num-traits" +version = "0.2.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "39e3200413f237f41ab11ad6d161bc7239c84dcb631773ccd7de3dfe4b5c267c" +dependencies = [ + "autocfg", +] + +[[package]] +name = "once_cell" +version = "1.18.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" + +[[package]] +name = "parking_lot" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c42a9226546d68acdd9c0a280d17ce19bfe27a46bf68784e4066115788d008e" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-targets", +] + +[[package]] +name = "pq-sys" +version = "0.4.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "31c0052426df997c0cbd30789eb44ca097e3541717a7b8fa36b1c464ee7edebd" +dependencies = [ + "vcpkg", +] + +[[package]] +name = "proc-macro2" +version = "1.0.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "134c189feb4956b20f6f547d2cf727d4c0fe06722b20a0eec87ed445a97f92da" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "quote" +version = "1.0.33" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "r2d2" +version = "0.8.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51de85fb3fb6524929c8a2eb85e6b6d363de4e8c48f9e2c2eac4944abc181c93" +dependencies = [ + "log", + "parking_lot", + "scheduled-thread-pool", +] + +[[package]] +name = "redox_syscall" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" +dependencies = [ + "bitflags 1.3.2", +] + +[[package]] +name = "rustix" +version = "0.38.21" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b426b0506e5d50a7d8dafcf2e81471400deb602392c7dd110815afb4eaf02a3" +dependencies = [ + "bitflags 2.4.1", + "errno", + "libc", + "linux-raw-sys", + "windows-sys", +] + +[[package]] +name = "scheduled-thread-pool" +version = "0.2.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3cbc66816425a074528352f5789333ecff06ca41b36b0b0efdfbb29edc391a19" +dependencies = [ + "parking_lot", +] + +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + +[[package]] +name = "smallvec" +version = "1.11.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "942b4a808e05215192e39f4ab80813e599068285906cc91aa64f923db842bd5a" + +[[package]] +name = "strsim" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" + +[[package]] +name = "syn" +version = "2.0.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e96b79aaa137db8f61e26363a0c9b47d8b4ec75da28b7d1d614c2303e232408b" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "terminal_size" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "21bebf2b7c9e0a515f6e0f8c51dc0f8e4696391e6f1ff30379559f8365fb0df7" +dependencies = [ + "rustix", + "windows-sys", +] + +[[package]] +name = "thiserror" +version = "1.0.50" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f9a7210f5c9a7156bb50aa36aed4c95afb51df0df00713949448cf9e97d382d2" +dependencies = [ + "thiserror-impl", +] + +[[package]] +name = "thiserror-impl" +version = "1.0.50" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "266b2e40bc00e5a6c09c3584011e08b06f123c00362c92b975ba9843aaaa14b8" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "todo" +version = "0.1.0" +dependencies = [ + "chrono", + "diesel", + "dsync", + "r2d2", +] + +[[package]] +name = "unicode-ident" +version = "1.0.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" + +[[package]] +name = "utf8parse" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "711b9620af191e0cdc7468a8d14e709c3dcdb115b36f838e601583af800a370a" + +[[package]] +name = "vcpkg" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" + +[[package]] +name = "wasm-bindgen" +version = "0.2.88" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7daec296f25a1bae309c0cd5c29c4b260e510e6d813c286b19eaadf409d40fce" +dependencies = [ + "cfg-if", + "wasm-bindgen-macro", +] + +[[package]] +name = "wasm-bindgen-backend" +version = "0.2.88" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e397f4664c0e4e428e8313a469aaa58310d302159845980fd23b0f22a847f217" +dependencies = [ + "bumpalo", + "log", + "once_cell", + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-macro" +version = "0.2.88" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5961017b3b08ad5f3fe39f1e79877f8ee7c23c5e5fd5eb80de95abc41f1f16b2" +dependencies = [ + "quote", + "wasm-bindgen-macro-support", +] + +[[package]] +name = "wasm-bindgen-macro-support" +version = "0.2.88" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c5353b8dab669f5e10f5bd76df26a9360c748f054f862ff5f3f8aae0c7fb3907" +dependencies = [ + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-backend", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-shared" +version = "0.2.88" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d046c5d029ba91a1ed14da14dca44b68bf2f124cfbaf741c54151fdb3e0750b" + +[[package]] +name = "windows-core" +version = "0.51.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f1f8cf84f35d2db49a46868f947758c7a1138116f7fac3bc844f43ade1292e64" +dependencies = [ + "windows-targets", +] + +[[package]] +name = "windows-sys" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" +dependencies = [ + "windows-targets", +] + +[[package]] +name = "windows-targets" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" +dependencies = [ + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", +] + +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" + +[[package]] +name = "windows_i686_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" + +[[package]] +name = "windows_i686_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" diff --git a/examples/Cargo.toml b/examples/Cargo.toml new file mode 100644 index 00000000..78d7ec91 --- /dev/null +++ b/examples/Cargo.toml @@ -0,0 +1,2 @@ +[workspace] +members = ["todo"] \ No newline at end of file diff --git a/examples/test_all.sh b/examples/test_all.sh new file mode 100755 index 00000000..fe4b52a5 --- /dev/null +++ b/examples/test_all.sh @@ -0,0 +1,18 @@ +#!/bin/bash + +# fail on non-0 exit codes, which makes it more obvious if a test has failed +set -e + +SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )" + +cd $SCRIPT_DIR + +for D in *; do + if [ -d "${D}" ]; then + echo "Running codegen and compiling '$D'" + cd $SCRIPT_DIR/$D + cargo run --bin dsync + cargo run --bin example + echo "" + fi +done diff --git a/examples/todo/Cargo.toml b/examples/todo/Cargo.toml new file mode 100644 index 00000000..f495e211 --- /dev/null +++ b/examples/todo/Cargo.toml @@ -0,0 +1,21 @@ +[[bin]] +name = "dsync" +path = "src/dsync.rs" + +[[bin]] +name = "example" +path = "src/example.rs" + +[package] +name = "todo" +version = "0.1.0" +edition = "2021" +default-run = "example" + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[dependencies] +diesel = {version="*", default-features = false, features=["postgres", "r2d2", "chrono"]} +r2d2 = "*" +dsync = {path = "../../"} +chrono = "*" diff --git a/examples/todo/src/dsync.rs b/examples/todo/src/dsync.rs new file mode 100644 index 00000000..271046e6 --- /dev/null +++ b/examples/todo/src/dsync.rs @@ -0,0 +1,26 @@ +use dsync::{GenerationConfig, TableOptions}; +use std::path::PathBuf; + +fn main() { + let dir = env!("CARGO_MANIFEST_DIR"); + + let schema_file = PathBuf::from_iter([dir, "src/schema.rs"]); + let models_dir = PathBuf::from_iter([dir, "src/models"]); + + dsync::generate_files( + schema_file.as_path(), + models_dir.as_path(), + GenerationConfig { + connection_type: "diesel::pg::PgConnection".into(), + default_table_options: TableOptions::default().disable_serde(), + model_path: "crate::models::".into(), + schema_path: "crate::schema::".into(), + once_common_structs: true, + once_connection_type: true, + readonly_prefixes: vec![], + readonly_suffixes: vec![], + table_options: Default::default(), + }, + ) + .unwrap(); +} diff --git a/examples/todo/src/example.rs b/examples/todo/src/example.rs new file mode 100644 index 00000000..edd31075 --- /dev/null +++ b/examples/todo/src/example.rs @@ -0,0 +1,10 @@ +extern crate diesel; + +mod models; +mod schema; + +use models::todo::Todo; + +fn main() { + println!("Hello, world!"); +} diff --git a/examples/todo/src/models/common.rs b/examples/todo/src/models/common.rs new file mode 100644 index 00000000..edf3fda2 --- /dev/null +++ b/examples/todo/src/models/common.rs @@ -0,0 +1,12 @@ +/* @generated and managed by dsync */ +#[derive(Debug, )] +pub struct PaginationResult { + pub items: Vec, + pub total_items: i64, + /// 0-based index + pub page: i64, + pub page_size: i64, + pub num_pages: i64, +} + +pub type ConnectionType = diesel::pg::PgConnection; diff --git a/examples/todo/src/models/mod.rs b/examples/todo/src/models/mod.rs new file mode 100644 index 00000000..22ad7726 --- /dev/null +++ b/examples/todo/src/models/mod.rs @@ -0,0 +1,2 @@ +pub mod common; +pub mod todo; diff --git a/examples/todo/src/models/todo/generated.rs b/examples/todo/src/models/todo/generated.rs new file mode 100644 index 00000000..bef667df --- /dev/null +++ b/examples/todo/src/models/todo/generated.rs @@ -0,0 +1,79 @@ +/* @generated and managed by dsync */ + +use crate::diesel::*; +use crate::schema::*; +use diesel::QueryResult; +use crate::models::common::*; + +#[derive(Debug, Clone, Queryable, Selectable)] +#[diesel(table_name=todo, primary_key(id))] +pub struct Todo { + pub id: i32, + pub text: String, + pub completed: bool, + pub created_at: chrono::DateTime, + pub updated_at: chrono::DateTime, +} + +#[derive(Debug, Clone, Insertable)] +#[diesel(table_name=todo)] +pub struct CreateTodo { + pub id: i32, + pub text: String, + pub completed: bool, + pub created_at: chrono::DateTime, + pub updated_at: chrono::DateTime, +} + +#[derive(Debug, Clone, AsChangeset, Default)] +#[diesel(table_name=todo)] +pub struct UpdateTodo { + pub text: Option, + pub completed: Option, + pub created_at: Option>, + pub updated_at: Option>, +} + +impl Todo { + pub fn create(db: &mut ConnectionType, item: &CreateTodo) -> QueryResult { + use crate::schema::todo::dsl::*; + + insert_into(todo).values(item).get_result::(db) + } + + pub fn read(db: &mut ConnectionType, param_id: i32) -> QueryResult { + use crate::schema::todo::dsl::*; + + todo.filter(id.eq(param_id)).first::(db) + } + + /// Paginates through the table where page is a 0-based index (i.e. page 0 is the first page) + pub fn paginate(db: &mut ConnectionType, page: i64, page_size: i64) -> QueryResult> { + use crate::schema::todo::dsl::*; + + let page_size = if page_size < 1 { 1 } else { page_size }; + let total_items = todo.count().get_result(db)?; + let items = todo.limit(page_size).offset(page * page_size).load::(db)?; + + Ok(PaginationResult { + items, + total_items, + page, + page_size, + /* ceiling division of integers */ + num_pages: total_items / page_size + i64::from(total_items % page_size != 0) + }) + } + + pub fn update(db: &mut ConnectionType, param_id: i32, item: &UpdateTodo) -> QueryResult { + use crate::schema::todo::dsl::*; + + diesel::update(todo.filter(id.eq(param_id))).set(item).get_result(db) + } + + pub fn delete(db: &mut ConnectionType, param_id: i32) -> QueryResult { + use crate::schema::todo::dsl::*; + + diesel::delete(todo.filter(id.eq(param_id))).execute(db) + } +} diff --git a/examples/todo/src/models/todo/mod.rs b/examples/todo/src/models/todo/mod.rs new file mode 100644 index 00000000..136e9a24 --- /dev/null +++ b/examples/todo/src/models/todo/mod.rs @@ -0,0 +1,2 @@ +pub mod generated; +pub use generated::*; diff --git a/examples/todo/src/schema.rs b/examples/todo/src/schema.rs new file mode 100644 index 00000000..2277f23b --- /dev/null +++ b/examples/todo/src/schema.rs @@ -0,0 +1,9 @@ +diesel::table! { + todo (id) { + id -> Int4, + text -> Text, + completed -> Bool, + created_at -> Timestamptz, + updated_at -> Timestamptz, + } +} From cec637fa0dd1f02168f05114ef93d375177be947 Mon Sep 17 00:00:00 2001 From: Haris <4259838+Wulf@users.noreply.github.com> Date: Mon, 1 Jan 2024 20:45:57 -0500 Subject: [PATCH 2/2] Switch examples/todo to use single_model_file generation --- examples/todo/src/dsync.rs | 2 +- examples/todo/src/models/common.rs | 7 +++++- .../src/models/{todo/generated.rs => todo.rs} | 25 +++++++++++++++++-- examples/todo/src/models/todo/mod.rs | 2 -- 4 files changed, 30 insertions(+), 6 deletions(-) rename examples/todo/src/models/{todo/generated.rs => todo.rs} (67%) delete mode 100644 examples/todo/src/models/todo/mod.rs diff --git a/examples/todo/src/dsync.rs b/examples/todo/src/dsync.rs index 271046e6..83e2625b 100644 --- a/examples/todo/src/dsync.rs +++ b/examples/todo/src/dsync.rs @@ -12,7 +12,7 @@ fn main() { models_dir.as_path(), GenerationConfig { connection_type: "diesel::pg::PgConnection".into(), - default_table_options: TableOptions::default().disable_serde(), + default_table_options: TableOptions::default().disable_serde().single_model_file(), model_path: "crate::models::".into(), schema_path: "crate::schema::".into(), once_common_structs: true, diff --git a/examples/todo/src/models/common.rs b/examples/todo/src/models/common.rs index edf3fda2..d8db5d1d 100644 --- a/examples/todo/src/models/common.rs +++ b/examples/todo/src/models/common.rs @@ -1,11 +1,16 @@ /* @generated and managed by dsync */ +/// Result of a `.paginate` function #[derive(Debug, )] pub struct PaginationResult { + /// Resulting items that are from the current page pub items: Vec, + /// The count of total items there are pub total_items: i64, - /// 0-based index + /// Current page, 0-based index pub page: i64, + /// Size of a page pub page_size: i64, + /// Number of total possible pages, given the `page_size` and `total_items` pub num_pages: i64, } diff --git a/examples/todo/src/models/todo/generated.rs b/examples/todo/src/models/todo.rs similarity index 67% rename from examples/todo/src/models/todo/generated.rs rename to examples/todo/src/models/todo.rs index bef667df..2077106e 100644 --- a/examples/todo/src/models/todo/generated.rs +++ b/examples/todo/src/models/todo.rs @@ -5,42 +5,61 @@ use crate::schema::*; use diesel::QueryResult; use crate::models::common::*; -#[derive(Debug, Clone, Queryable, Selectable)] +/// Struct representing a row in table `todo` +#[derive(Debug, Clone, Queryable, Selectable, QueryableByName)] #[diesel(table_name=todo, primary_key(id))] pub struct Todo { + /// Field representing column `id` pub id: i32, + /// Field representing column `text` pub text: String, + /// Field representing column `completed` pub completed: bool, + /// Field representing column `created_at` pub created_at: chrono::DateTime, + /// Field representing column `updated_at` pub updated_at: chrono::DateTime, } +/// Create Struct for a row in table `todo` for [`Todo`] #[derive(Debug, Clone, Insertable)] #[diesel(table_name=todo)] pub struct CreateTodo { + /// Field representing column `id` pub id: i32, + /// Field representing column `text` pub text: String, + /// Field representing column `completed` pub completed: bool, + /// Field representing column `created_at` pub created_at: chrono::DateTime, + /// Field representing column `updated_at` pub updated_at: chrono::DateTime, } -#[derive(Debug, Clone, AsChangeset, Default)] +/// Update Struct for a row in table `todo` for [`Todo`] +#[derive(Debug, Clone, AsChangeset, PartialEq, Default)] #[diesel(table_name=todo)] pub struct UpdateTodo { + /// Field representing column `text` pub text: Option, + /// Field representing column `completed` pub completed: Option, + /// Field representing column `created_at` pub created_at: Option>, + /// Field representing column `updated_at` pub updated_at: Option>, } impl Todo { + /// Insert a new row into `todo` with a given [`CreateTodo`] pub fn create(db: &mut ConnectionType, item: &CreateTodo) -> QueryResult { use crate::schema::todo::dsl::*; insert_into(todo).values(item).get_result::(db) } + /// Get a row from `todo`, identified by the primary key pub fn read(db: &mut ConnectionType, param_id: i32) -> QueryResult { use crate::schema::todo::dsl::*; @@ -65,12 +84,14 @@ impl Todo { }) } + /// Update a row in `todo`, identified by the primary key with [`UpdateTodo`] pub fn update(db: &mut ConnectionType, param_id: i32, item: &UpdateTodo) -> QueryResult { use crate::schema::todo::dsl::*; diesel::update(todo.filter(id.eq(param_id))).set(item).get_result(db) } + /// Delete a row in `todo`, identified by the primary key pub fn delete(db: &mut ConnectionType, param_id: i32) -> QueryResult { use crate::schema::todo::dsl::*; diff --git a/examples/todo/src/models/todo/mod.rs b/examples/todo/src/models/todo/mod.rs deleted file mode 100644 index 136e9a24..00000000 --- a/examples/todo/src/models/todo/mod.rs +++ /dev/null @@ -1,2 +0,0 @@ -pub mod generated; -pub use generated::*;