-
Notifications
You must be signed in to change notification settings - Fork 4.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix continuation of JSON deserialization #42158
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the PR! I requested a few more tests.
src/libraries/System.Text.Json/tests/Serialization/ContinuationTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Text.Json/tests/Serialization/ContinuationTests.cs
Outdated
Show resolved
Hide resolved
- Test continuation at every position inside the tested object - Many member with primitive and nullable types - One more level of nested object - All combinations of class/struct for tested and nested object - tested and nested object with parametrized ctor for some properties
src/libraries/System.Text.Json/tests/Serialization/StreamTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Text.Json/tests/Serialization/StreamTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Text.Json/src/System/Text/Json/Serialization/JsonPropertyInfoOfT.cs
Show resolved
Hide resolved
src/libraries/System.Text.Json/tests/Serialization/StreamTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Text.Json/tests/Serialization/StreamTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Text.Json/tests/Serialization/StreamTests.cs
Outdated
Show resolved
Hide resolved
src/libraries/System.Text.Json/tests/Serialization/StreamTests.cs
Outdated
Show resolved
Hide resolved
private const int MinPaddingLength = 5; | ||
private const int MaxPaddingLength = 116; | ||
|
||
private static IEnumerable<int> ContinuationPaddingLengths | ||
=> Enumerable.Range(MinPaddingLength, MaxPaddingLength - MinPaddingLength + 1); | ||
|
||
private static IEnumerable<bool> IgnoreNullValues | ||
=> new[] { true, false }; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These are great tests and a clever way to get a lot more continuation coverage! Nicely done.
If you are up for it, I think it would be really valuable to do a similar thing with the Utf8JsonReader
overload of JsonSerialier.Deserialize
(probably in a separate PR), which also supports continuation/partial buffers via the ReadOnlySequence<byte>
(where the whole JSON is available in memory, but split in non-contiguous chunks).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks!
I will have a look.
If feasible (and quick to run), can we also add to the test test a standalone copy of the "regression" test that was initially reported on the issue: #42070 (comment) That way, that exact customer reported scenario is guarded against in the test. Similar to these (that were also inspired from the reported issue): Line 19 in 6072e4d
runtime/src/libraries/System.Text.Json/tests/Utf8JsonReaderTests.TryGet.Date.cs Lines 150 to 152 in 5285c14
runtime/src/libraries/System.Text.Json/tests/Utf8JsonWriterTests.cs Lines 3091 to 3097 in 5285c14
runtime/src/libraries/System.Text.Json/tests/Serialization/Object.ReadTests.cs Lines 111 to 112 in 5285c14
runtime/src/libraries/System.Text.Json/tests/Serialization/ReadValueTests.cs Lines 671 to 673 in 5285c14
|
I was thinking about that but there are some obstacles. The original repro depends on some third party packages. Besides that it is not deterministic because nobody knew the root cause at this time. Sometimes it runs for minutes until randomly a null token gets hit by the continuation. |
@devsko / @ahsonkhan - thank you for looking into this. I have added code to save failing examples to the repro - the failing json examples are around 100KB. Maybe a few of these could be used for regression tests? Also, the captured output includes some examples of a NullReferenceException - in addition to examples of the more common InvalidOperationException - for example, 0228. @am11 noted a NullReferenceException and I have seen this twice with real data. Does the fix for the InvalidOperationExceptions also fix the NullReferenceExceptions? |
Great! Thank you. I will add a test for each observed exception type.
It does. |
src/libraries/System.Text.Json/tests/Serialization/StreamTests.cs
Outdated
Show resolved
Hide resolved
@@ -0,0 +1 @@ | |||
{"customers":[{"id":-935344204198316476,"email":"Eric61@hotmail.com","accepts_marketing":false,"created_at":"2020-09-16T03:00:37.9507057+01:00","updated_at":"2020-09-15T14:59:58.4926562+01:00","first_name":"Dedric","last_name":"Reinger","orders_count":1672035651,"state":"Delaware","total_spent":"invoice","last_order_id":-611951626428354704,"note":"Assistant","verified_email":true,"multipass_identifier":"supply-chains","tax_exempt":false,"tags":"Cloned","last_order_name":"Handmade Concrete Chicken","default_address":{"first_name":"Ivory","address1":"Frank Rest","phone":"leverage","city":"North Derrick","zip":"matrix","province":null,"country":"Canada","last_name":"Prohaska","address2":null,"company":"e-services","latitude":0.19789267,"longitude":0.9847119,"name":"yellow","country_code":"MY","province_code":"AI"},"addresses":[{"first_name":"Frida","address1":"Concrete","phone":"channels","city":"Ibrahimberg","zip":"convergence","province":"Up-sized","country":"Macedonia","last_name":"Kertzmann","address2":"Money Market Account","company":"turquoise","latitude":0.590819,"longitude":0.85476744,"name":"exploit","country_code":"FM","province_code":"Investor"},{"first_name":"Lester","address1":"HDD","phone":"Ergonomic Fresh Ball","city":"Kihnmouth","zip":"Republic of Korea","province":"Alaska","country":"Somalia","last_name":"Reinger","address2":"schemas","company":"Minnesota","latitude":0.19687825,"longitude":0.3193893,"name":"strategy","country_code":"HN","province_code":"Jordanian Dinar"},{"first_name":"Summer","address1":"Prairie","phone":"Credit Card Account","city":"North Jadenfort","zip":"mesh","province":"Graphical User Interface","country":"Bermuda","last_name":"Beahan","address2":"hard drive","company":"circuit","latitude":0.32408917,"longitude":0.8158973,"name":"Mountains","country_code":"MA","province_code":"Games"},{"first_name":"Ivory","address1":"Frank Rest","phone":"leverage","city":"North Derrick","zip":"matrix","province":null,"country":"Canada","last_name":"Prohaska","address2":null,"company":"e-services","latitude":0.19789267,"longitude":0.9847119,"name":"yellow","country_code":"MY","province_code":"AI"}]},{"id":3704774345270501476,"email":"Wilfred_Langworth15@hotmail.com","accepts_marketing":false,"created_at":"2020-09-16T09:58:14.3648708+01:00","updated_at":"2020-09-16T08:33:24.943768+01:00","first_name":"Alicia","last_name":"Halvorson","orders_count":-483442060,"state":"Texas","total_spent":"Music","last_order_id":-2487139932192648785,"note":"Lao People\u0027s Democratic Republic","verified_email":false,"multipass_identifier":"synthesize","tax_exempt":true,"tags":"User-centric","last_order_name":"Tasty Wooden Hat","default_address":{"first_name":"Janet","address1":"Heathcote Brooks","phone":"cultivate","city":"Morarchester","zip":"Fresh","province":null,"country":"Mongolia","last_name":"Runte","address2":"Raynor Manor","company":"Buckinghamshire","latitude":0.7157712,"longitude":0.9835676,"name":"South Carolina","country_code":"PT","province_code":"payment"},"addresses":[{"first_name":"Felipa","address1":"Incredible Granite Fish","phone":"Branding","city":"Cronaburgh","zip":"transmit","province":"Fantastic","country":"Mayotte","last_name":"Denesik","address2":"calculate","company":"Incredible","latitude":0.7200533,"longitude":0.54565936,"name":"Auto Loan Account","country_code":"IT","province_code":"Internal"},{"first_name":"Dorothea","address1":"Usability","phone":"Intelligent Concrete Pizza","city":"Alessiaside","zip":"Auto Loan Account","province":"SSL","country":"Central African Republic","last_name":"Hoeger","address2":"architect","company":"Metal","latitude":0.9113026,"longitude":0.66658276,"name":"Internal","country_code":"AI","province_code":"maroon"},{"first_name":"Garnett","address1":"Virgin Islands, British","phone":"Direct","city":"Lillietown","zip":"Gorgeous","province":"Beauty","country":"Liberia","last_name":"Reinger","address2":"Home \u0026 Electronics","company":"Credit Card Account","latitude":0.8475008,"longitude":0.075884424,"name":"District","country_code":"MP","province_code":"SCSI"},{"first_name":"Janet","address1":"Heathcote Brooks","phone":"cultivate","city":"Morarchester","zip":"Fresh","province":null,"country":"Mongolia","last_name":"Runte","address2":"Raynor Manor","company":"Buckinghamshire","latitude":0.7157712,"longitude":0.9835676,"name":"South Carolina","country_code":"PT","province_code":"payment"}]},{"id":-530482075379783136,"email":"Grace_Kemmer27@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T17:44:15.9463652+01:00","updated_at":"2020-09-15T12:24:28.4599649+01:00","first_name":"Nicholaus","last_name":"Oberbrunner","orders_count":1859369484,"state":"Alabama","total_spent":"Analyst","last_order_id":2792372091146531080,"note":"Extensions","verified_email":true,"multipass_identifier":"Afghani","tax_exempt":true,"tags":"Pennsylvania","last_order_name":"Savings Account","default_address":{"first_name":"Floy","address1":"Ashleigh Summit","phone":"copying","city":"Connorborough","zip":"Licensed","province":null,"country":"Norway","last_name":"Mueller","address2":null,"company":"partnerships","latitude":0.03793659,"longitude":0.67998004,"name":"e-business","country_code":"IL","province_code":"rich"},"addresses":[{"first_name":"Valerie","address1":"Internal","phone":"Square","city":"Abernathyshire","zip":"haptic","province":"Investor","country":"Yemen","last_name":"Bosco","address2":"Common","company":"Data","latitude":0.21591519,"longitude":0.63000464,"name":"overriding","country_code":"KG","province_code":"calculate"},{"first_name":"Joelle","address1":"Incredible Concrete Keyboard","phone":"Directives","city":"Corwintown","zip":"RAM","province":"Home Loan Account","country":"Aruba","last_name":"Cassin","address2":"Roads","company":"Music","latitude":0.08540865,"longitude":0.15794277,"name":"Branding","country_code":"JE","province_code":"Auto Loan Account"},{"first_name":"Nola","address1":"input","phone":"Arizona","city":"Torphystad","zip":"compressing","province":"solid state","country":"Zambia","last_name":"Kessler","address2":"Usability","company":"Identity","latitude":0.9348627,"longitude":0.84375966,"name":"Incredible","country_code":"KG","province_code":"override"},{"first_name":"Floy","address1":"Ashleigh Summit","phone":"copying","city":"Connorborough","zip":"Licensed","province":null,"country":"Norway","last_name":"Mueller","address2":null,"company":"partnerships","latitude":0.03793659,"longitude":0.67998004,"name":"e-business","country_code":"IL","province_code":"rich"}]},{"id":-116896945288416204,"email":"Gerald76@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T14:38:34.1926906+01:00","updated_at":"2020-09-15T20:28:06.3025405+01:00","first_name":"Colten","last_name":"Tromp","orders_count":1051569596,"state":"South Carolina","total_spent":"Exclusive","last_order_id":-5887989639698761757,"note":"deposit","verified_email":true,"multipass_identifier":"Fresh","tax_exempt":false,"tags":"Refined Plastic Cheese","last_order_name":"Product","default_address":{"first_name":"Maxime","address1":"Eudora Track","phone":"Supervisor","city":"Bernierburgh","zip":"payment","province":null,"country":"Angola","last_name":"Schaden","address2":null,"company":"optical","latitude":0.68218356,"longitude":0.69233084,"name":"PNG","country_code":"GR","province_code":"Movies, Clothing \u0026 Movies"},"addresses":[{"first_name":"Charity","address1":"Soft","phone":"Wooden","city":"Sawaynville","zip":"River","province":"neural","country":"Guadeloupe","last_name":"Bechtelar","address2":"neural","company":"Liberian Dollar","latitude":0.9746022,"longitude":0.48044038,"name":"Crossing","country_code":"AG","province_code":"silver"},{"first_name":"Eloise","address1":"Facilitator","phone":"facilitate","city":"East Howard","zip":"quantifying","province":"solid state","country":"Indonesia","last_name":"Huel","address2":"synergize","company":"intuitive","latitude":0.61845183,"longitude":0.9904602,"name":"Sleek Wooden Mouse","country_code":"AX","province_code":"generating"},{"first_name":"Annette","address1":"Berkshire","phone":"Specialist","city":"Lake Lucioville","zip":"multi-byte","province":"Track","country":"Mauritius","last_name":"Reichel","address2":"navigate","company":"French Guiana","latitude":0.31113178,"longitude":0.09412532,"name":"Ergonomic Rubber Sausages","country_code":"LU","province_code":"next-generation"},{"first_name":"Maxime","address1":"Eudora Track","phone":"Supervisor","city":"Bernierburgh","zip":"payment","province":null,"country":"Angola","last_name":"Schaden","address2":null,"company":"optical","latitude":0.68218356,"longitude":0.69233084,"name":"PNG","country_code":"GR","province_code":"Movies, Clothing \u0026 Movies"}]},{"id":7483885748311579922,"email":"Michelle_Zieme@yahoo.com","accepts_marketing":true,"created_at":"2020-09-16T09:04:07.9573546+01:00","updated_at":"2020-09-15T21:31:30.22573+01:00","first_name":"Kenny","last_name":"Wisozk","orders_count":1450176788,"state":"Rhode Island","total_spent":"client-driven","last_order_id":3716817613962710792,"note":"Developer","verified_email":false,"multipass_identifier":"Awesome Concrete Gloves","tax_exempt":false,"tags":"backing up","last_order_name":"Practical Wooden Chicken","default_address":{"first_name":"Doug","address1":"Padberg Shore","phone":"Port","city":"Hoppeberg","zip":"Handcrafted Metal Car","province":null,"country":"Nigeria","last_name":"Smitham","address2":null,"company":"copying","latitude":0.08108864,"longitude":0.0016318182,"name":"Product","country_code":"OM","province_code":"generating"},"addresses":[{"first_name":"Vincenza","address1":"grow","phone":"Kids \u0026 Electronics","city":"South Stuart","zip":"vortals","province":"withdrawal","country":"Lao People\u0027s Democratic Republic","last_name":"Kerluke","address2":"compressing","company":"Mississippi","latitude":0.17093733,"longitude":0.9188159,"name":"Throughway","country_code":"MU","province_code":"Generic"},{"first_name":"Rebeka","address1":"Seamless","phone":"hard drive","city":"Aubreymouth","zip":"transmitter","province":"SDD","country":"Pitcairn Islands","last_name":"Davis","address2":"6th generation","company":"application","latitude":0.8919196,"longitude":0.9163776,"name":"CFP Franc","country_code":"ML","province_code":"invoice"},{"first_name":"Kali","address1":"Denar","phone":"mindshare","city":"Port Isaac","zip":"Rubber","province":"input","country":"Gabon","last_name":"Zulauf","address2":"quantifying","company":"Small Soft Ball","latitude":0.99345773,"longitude":0.06183699,"name":"JSON","country_code":"RU","province_code":"red"},{"first_name":"Doug","address1":"Padberg Shore","phone":"Port","city":"Hoppeberg","zip":"Handcrafted Metal Car","province":null,"country":"Nigeria","last_name":"Smitham","address2":null,"company":"copying","latitude":0.08108864,"longitude":0.0016318182,"name":"Product","country_code":"OM","province_code":"generating"}]},{"id":3276971258515054813,"email":"Pat_Prosacco90@yahoo.com","accepts_marketing":false,"created_at":"2020-09-16T00:52:19.9422285+01:00","updated_at":"2020-09-16T01:37:16.5803231+01:00","first_name":"Nyasia","last_name":"Shanahan","orders_count":-1129453887,"state":"Texas","total_spent":"lime","last_order_id":8623365466101425435,"note":"success","verified_email":false,"multipass_identifier":"Clothing","tax_exempt":true,"tags":"Rustic Metal Computer","last_order_name":"deposit","default_address":{"first_name":"Tyrel","address1":"Arvilla Well","phone":"Producer","city":"Grimesberg","zip":"sensor","province":null,"country":"Vietnam","last_name":"Cremin","address2":null,"company":"Tasty Granite Keyboard","latitude":0.20239368,"longitude":0.15317804,"name":"cross-platform","country_code":"PG","province_code":"Creative"},"addresses":[{"first_name":"Jedediah","address1":"Savings Account","phone":"Station","city":"Winonastad","zip":"Credit Card Account","province":"Unions","country":"Somalia","last_name":"Collins","address2":"PCI","company":"Generic","latitude":0.9473291,"longitude":0.3905733,"name":"virtual","country_code":"UZ","province_code":"invoice"},{"first_name":"Jaylan","address1":"European Unit of Account 17(E.U.A.-17)","phone":"background","city":"Williamborough","zip":"Tools, Tools \u0026 Health","province":"Wisconsin","country":"Madagascar","last_name":"Johnston","address2":"silver","company":"integrate","latitude":0.6551266,"longitude":0.9557659,"name":"application","country_code":"CK","province_code":"District"},{"first_name":"Kaitlin","address1":"Tasty","phone":"Licensed Granite Pizza","city":"Port Alexport","zip":"Marketing","province":"applications","country":"Republic of Korea","last_name":"Mann","address2":"local","company":"Moldovan Leu","latitude":0.18770146,"longitude":0.47887808,"name":"Fantastic Steel Fish","country_code":"JO","province_code":"Heard Island and McDonald Islands"},{"first_name":"Tyrel","address1":"Arvilla Well","phone":"Producer","city":"Grimesberg","zip":"sensor","province":null,"country":"Vietnam","last_name":"Cremin","address2":null,"company":"Tasty Granite Keyboard","latitude":0.20239368,"longitude":0.15317804,"name":"cross-platform","country_code":"PG","province_code":"Creative"}]},{"id":-1585190108053595722,"email":"Stephen_Ernser@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T12:20:56.8658014+01:00","updated_at":"2020-09-16T10:27:12.6273901+01:00","first_name":"Lelah","last_name":"O\u0027Keefe","orders_count":-836840707,"state":"Georgia","total_spent":"Prairie","last_order_id":5434694616359624546,"note":"paradigms","verified_email":false,"multipass_identifier":"Sports, Home \u0026 Electronics","tax_exempt":false,"tags":"View","last_order_name":"SAS","default_address":{"first_name":"Joy","address1":"Dooley Spurs","phone":"generate","city":"Lake Demetrius","zip":"Small","province":null,"country":"Italy","last_name":"Thiel","address2":null,"company":"Engineer","latitude":0.25733364,"longitude":0.70836604,"name":"Intranet","country_code":"BW","province_code":"Romania"},"addresses":[{"first_name":"Patsy","address1":"haptic","phone":"Bedfordshire","city":"New Viva","zip":"mint green","province":"De-engineered","country":"Tonga","last_name":"Bartell","address2":"schemas","company":"Cotton","latitude":0.67086446,"longitude":0.87201804,"name":"Borders","country_code":"FO","province_code":"Berkshire"},{"first_name":"Raymond","address1":"Concrete","phone":"grey","city":"Hilllfurt","zip":"Guarani","province":"withdrawal","country":"Guyana","last_name":"Senger","address2":"e-enable","company":"integrated","latitude":0.42772233,"longitude":0.6698717,"name":"bus","country_code":"BG","province_code":"orchid"},{"first_name":"Cornell","address1":"withdrawal","phone":"concept","city":"Schaeferside","zip":"Wisconsin","province":"Fresh","country":"Zambia","last_name":"Swaniawski","address2":"Crossroad","company":"overriding","latitude":0.51890975,"longitude":0.6235244,"name":"brand","country_code":"LU","province_code":"Consultant"},{"first_name":"Joy","address1":"Dooley Spurs","phone":"generate","city":"Lake Demetrius","zip":"Small","province":null,"country":"Italy","last_name":"Thiel","address2":null,"company":"Engineer","latitude":0.25733364,"longitude":0.70836604,"name":"Intranet","country_code":"BW","province_code":"Romania"}]},{"id":-8962648194513335250,"email":"Rodney.Daugherty@gmail.com","accepts_marketing":true,"created_at":"2020-09-16T04:13:20.5844045+01:00","updated_at":"2020-09-15T20:57:35.9763116+01:00","first_name":"Santino","last_name":"Kuhlman","orders_count":1648295661,"state":"Oregon","total_spent":"Games","last_order_id":-7254593009232841610,"note":"Walk","verified_email":true,"multipass_identifier":"Branding","tax_exempt":true,"tags":"1080p","last_order_name":"SAS","default_address":{"first_name":"Demetris","address1":"Jamal Plains","phone":"Rustic Frozen Shoes","city":"Barrytown","zip":"payment","province":null,"country":"Costa Rica","last_name":"Monahan","address2":null,"company":"Rubber","latitude":0.12258957,"longitude":0.55700487,"name":"online","country_code":"CA","province_code":"San Marino"},"addresses":[{"first_name":"Felix","address1":"Beauty","phone":"GB","city":"Lake Siennaton","zip":"Fantastic Plastic Mouse","province":"Rapid","country":"Saint Helena","last_name":"Gislason","address2":"generating","company":"PCI","latitude":0.88084525,"longitude":0.31826815,"name":"copy","country_code":"BG","province_code":"technologies"},{"first_name":"Monica","address1":"cross-media","phone":"enable","city":"Nyasiafort","zip":"solid state","province":"Chief","country":"Antarctica (the territory South of 60 deg S)","last_name":"Greenfelder","address2":"standardization","company":"auxiliary","latitude":0.6025949,"longitude":0.64516723,"name":"Response","country_code":"TZ","province_code":"Courts"},{"first_name":"Foster","address1":"parsing","phone":"application","city":"West Robbiebury","zip":"paradigms","province":"Berkshire","country":"South Africa","last_name":"Smitham","address2":"Crossroad","company":"European Unit of Account 17(E.U.A.-17)","latitude":0.60103285,"longitude":0.4871379,"name":"Lead","country_code":"AO","province_code":"context-sensitive"},{"first_name":"Demetris","address1":"Jamal Plains","phone":"Rustic Frozen Shoes","city":"Barrytown","zip":"payment","province":null,"country":"Costa Rica","last_name":"Monahan","address2":null,"company":"Rubber","latitude":0.12258957,"longitude":0.55700487,"name":"online","country_code":"CA","province_code":"San Marino"}]},{"id":1081478456468077813,"email":"Lucille_Langosh53@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T20:16:34.7638794+01:00","updated_at":"2020-09-16T04:15:29.6801066+01:00","first_name":"Bailee","last_name":"Walker","orders_count":-428555183,"state":"Missouri","total_spent":"global","last_order_id":957154013777826560,"note":"Avon","verified_email":true,"multipass_identifier":"Representative","tax_exempt":false,"tags":"SMS","last_order_name":"bypass","default_address":{"first_name":"Vidal","address1":"Cyrus Key","phone":"salmon","city":"North Stephonmouth","zip":"HTTP","province":null,"country":"Algeria","last_name":"Boehm","address2":null,"company":"pink","latitude":0.8266832,"longitude":0.50448346,"name":"Exclusive","country_code":"LB","province_code":"24 hour"},"addresses":[{"first_name":"Leonard","address1":"Handmade Plastic Pizza","phone":"functionalities","city":"Port Meaganburgh","zip":"Gorgeous Granite Salad","province":"Identity","country":"Bhutan","last_name":"Jerde","address2":"Refined Rubber Cheese","company":"Orchestrator","latitude":0.4362225,"longitude":0.1290338,"name":"mesh","country_code":"HU","province_code":"multi-byte"},{"first_name":"Laila","address1":"even-keeled","phone":"artificial intelligence","city":"New Johathanside","zip":"Organic","province":"24/7","country":"United Kingdom","last_name":"Block","address2":"TCP","company":"XSS","latitude":0.015712922,"longitude":0.38088992,"name":"Creative","country_code":"KE","province_code":"parsing"},{"first_name":"Mckenzie","address1":"Missouri","phone":"white","city":"Jamieburgh","zip":"encoding","province":"productize","country":"Egypt","last_name":"Reichel","address2":"holistic","company":"revolutionary","latitude":0.16961037,"longitude":0.7674743,"name":"silver","country_code":"IE","province_code":"Gateway"},{"first_name":"Vidal","address1":"Cyrus Key","phone":"salmon","city":"North Stephonmouth","zip":"HTTP","province":null,"country":"Algeria","last_name":"Boehm","address2":null,"company":"pink","latitude":0.8266832,"longitude":0.50448346,"name":"Exclusive","country_code":"LB","province_code":"24 hour"}]},{"id":3237444116125812858,"email":"Terri.Botsford51@hotmail.com","accepts_marketing":false,"created_at":"2020-09-16T04:09:33.2617083+01:00","updated_at":"2020-09-15T13:20:41.9100944+01:00","first_name":"Gail","last_name":"Marvin","orders_count":1276136766,"state":"New Hampshire","total_spent":"process improvement","last_order_id":-3751086290450053603,"note":"Practical","verified_email":true,"multipass_identifier":"leverage","tax_exempt":true,"tags":"Infrastructure","last_order_name":"blue","default_address":{"first_name":"Rosa","address1":"Ewell Drives","phone":"Metrics","city":"Elizabethbury","zip":"parse","province":null,"country":"Equatorial Guinea","last_name":"Witting","address2":null,"company":"auxiliary","latitude":0.5015221,"longitude":0.738851,"name":"Customer","country_code":"LV","province_code":"Arizona"},"addresses":[{"first_name":"Mozelle","address1":"wireless","phone":"panel","city":"Alleneburgh","zip":"reboot","province":"withdrawal","country":"Holy See (Vatican City State)","last_name":"Carter","address2":"payment","company":"Ergonomic Metal Soap","latitude":0.68563914,"longitude":0.012578824,"name":"Avon","country_code":"HK","province_code":"Awesome"},{"first_name":"Rickie","address1":"Technician","phone":"Plains","city":"South Monserrate","zip":"Landing","province":"monitor","country":"Aruba","last_name":"Strosin","address2":"Steel","company":"Lead","latitude":0.81533265,"longitude":0.66934526,"name":"purple","country_code":"TJ","province_code":"quantifying"},{"first_name":"Hugh","address1":"Austria","phone":"deposit","city":"Port Hermannton","zip":"holistic","province":"neural","country":"Netherlands","last_name":"Rempel","address2":"South Dakota","company":"visionary","latitude":0.894841,"longitude":0.2548093,"name":"Refined","country_code":"VG","province_code":"Falkland Islands Pound"},{"first_name":"Rosa","address1":"Ewell Drives","phone":"Metrics","city":"Elizabethbury","zip":"parse","province":null,"country":"Equatorial Guinea","last_name":"Witting","address2":null,"company":"auxiliary","latitude":0.5015221,"longitude":0.738851,"name":"Customer","country_code":"LV","province_code":"Arizona"}]},{"id":-4557979460263118494,"email":"Van.OReilly44@hotmail.com","accepts_marketing":true,"created_at":"2020-09-16T11:32:12.5387538+01:00","updated_at":"2020-09-16T11:30:12.9147156+01:00","first_name":"Silas","last_name":"Hintz","orders_count":-1140601548,"state":"Delaware","total_spent":"contextually-based","last_order_id":579683202111036939,"note":"Tasty Wooden Towels","verified_email":false,"multipass_identifier":"Specialist","tax_exempt":false,"tags":"innovative","last_order_name":"Avon","default_address":{"first_name":"Nathanial","address1":"Batz Drives","phone":"redundant","city":"Kaseyside","zip":"bandwidth-monitored","province":null,"country":"Niger","last_name":"Kautzer","address2":null,"company":"neural","latitude":0.93882453,"longitude":0.45056129,"name":"Haven","country_code":"TH","province_code":"whiteboard"},"addresses":[{"first_name":"Amy","address1":"metrics","phone":"index","city":"Grimesland","zip":"mindshare","province":"Trail","country":"Myanmar","last_name":"Harvey","address2":"rich","company":"Grocery \u0026 Music","latitude":0.6045588,"longitude":0.12963544,"name":"target","country_code":"GT","province_code":"Upgradable"},{"first_name":"Ashton","address1":"Green","phone":"Research","city":"West Dock","zip":"haptic","province":"synergistic","country":"Martinique","last_name":"Hilpert","address2":"Bedfordshire","company":"motivating","latitude":0.05830681,"longitude":0.4626939,"name":"1080p","country_code":"CV","province_code":"Applications"},{"first_name":"Rick","address1":"Cotton","phone":"red","city":"Lake Peggiestad","zip":"Licensed Granite Bacon","province":"mobile","country":"Guatemala","last_name":"Olson","address2":"Dynamic","company":"Refined Fresh Chips","latitude":0.057386585,"longitude":0.86981285,"name":"Handmade Concrete Chips","country_code":"BD","province_code":"Tasty Rubber Mouse"},{"first_name":"Nathanial","address1":"Batz Drives","phone":"redundant","city":"Kaseyside","zip":"bandwidth-monitored","province":null,"country":"Niger","last_name":"Kautzer","address2":null,"company":"neural","latitude":0.93882453,"longitude":0.45056129,"name":"Haven","country_code":"TH","province_code":"whiteboard"}]},{"id":-62542098317725501,"email":"Jason_Smitham56@hotmail.com","accepts_marketing":false,"created_at":"2020-09-16T00:21:01.5896435+01:00","updated_at":"2020-09-15T16:10:12.7503306+01:00","first_name":"Sydnie","last_name":"Kovacek","orders_count":1407563604,"state":"Michigan","total_spent":"Grocery","last_order_id":7743585309671907756,"note":"Jersey","verified_email":true,"multipass_identifier":"Handcrafted","tax_exempt":false,"tags":"Gorgeous Steel Towels","last_order_name":"Shoes, Games \u0026 Music","default_address":{"first_name":"Dudley","address1":"Reilly Branch","phone":"Front-line","city":"Flavieburgh","zip":"utilize","province":"Rhode Island","country":"Pitcairn Islands","last_name":"Hand","address2":null,"company":"Ergonomic","latitude":0.9107813,"longitude":0.13326702,"name":"Shoes \u0026 Outdoors","country_code":"BF","province_code":"deliverables"},"addresses":[{"first_name":"Gracie","address1":"Representative","phone":"input","city":"North Gabe","zip":"transmit","province":"Sleek Rubber Soap","country":"Ethiopia","last_name":"Shanahan","address2":"Berkshire","company":"solid state","latitude":0.011037063,"longitude":0.8534697,"name":"Brazil","country_code":"CR","province_code":"backing up"},{"first_name":"Zora","address1":"Awesome Rubber Pants","phone":"utilisation","city":"Weststad","zip":"Interactions","province":"relationships","country":"Brunei Darussalam","last_name":"Bosco","address2":"Cotton","company":"stable","latitude":0.6368937,"longitude":0.36168513,"name":"e-tailers","country_code":"HK","province_code":"Berkshire"},{"first_name":"Gabrielle","address1":"Mountain","phone":"French Southern Territories","city":"East Laronville","zip":"Rustic Soft Bacon","province":"RSS","country":"Anguilla","last_name":"Leffler","address2":"payment","company":"Mauritius Rupee","latitude":0.22505309,"longitude":0.34152025,"name":"Multi-channelled","country_code":"SD","province_code":"Practical Rubber Cheese"},{"first_name":"Dudley","address1":"Reilly Branch","phone":"Front-line","city":"Flavieburgh","zip":"utilize","province":"Rhode Island","country":"Pitcairn Islands","last_name":"Hand","address2":null,"company":"Ergonomic","latitude":0.9107813,"longitude":0.13326702,"name":"Shoes \u0026 Outdoors","country_code":"BF","province_code":"deliverables"}]},{"id":5981493130770576027,"email":"Jeannie_Okuneva68@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T23:33:52.5316359+01:00","updated_at":"2020-09-15T23:09:29.9929318+01:00","first_name":"Abelardo","last_name":"Ruecker","orders_count":1218656294,"state":"Montana","total_spent":"Belarus","last_order_id":-3568432601260302723,"note":"orange","verified_email":false,"multipass_identifier":"Music \u0026 Health","tax_exempt":false,"tags":"B2B","last_order_name":"withdrawal","default_address":{"first_name":"Glenda","address1":"Paxton Valleys","phone":"Indiana","city":"Ernestochester","zip":"Bedfordshire","province":null,"country":"Kuwait","last_name":"Walter","address2":null,"company":"Tasty Metal Chips","latitude":0.79745126,"longitude":0.78436863,"name":"Garden \u0026 Industrial","country_code":"BH","province_code":"Money Market Account"},"addresses":[{"first_name":"Alexandre","address1":"channels","phone":"sticky","city":"Arjunmouth","zip":"Sleek","province":"Turnpike","country":"Liechtenstein","last_name":"Ruecker","address2":"Sleek Granite Ball","company":"next generation","latitude":0.8428317,"longitude":0.20411944,"name":"Oklahoma","country_code":"UY","province_code":"EXE"},{"first_name":"Josh","address1":"SSL","phone":"Manors","city":"East Lucienneton","zip":"Savings Account","province":"engage","country":"Trinidad and Tobago","last_name":"Wunsch","address2":"synthesize","company":"local area network","latitude":0.5903688,"longitude":0.3583586,"name":"Isle","country_code":"VG","province_code":"Jersey"},{"first_name":"Colten","address1":"Frozen","phone":"Tajikistan","city":"Abdielland","zip":"Rustic","province":"Shoes","country":"Bulgaria","last_name":"O\u0027Reilly","address2":"impactful","company":"tangible","latitude":0.66297144,"longitude":0.63648915,"name":"Texas","country_code":"EE","province_code":"Toys"},{"first_name":"Glenda","address1":"Paxton Valleys","phone":"Indiana","city":"Ernestochester","zip":"Bedfordshire","province":null,"country":"Kuwait","last_name":"Walter","address2":null,"company":"Tasty Metal Chips","latitude":0.79745126,"longitude":0.78436863,"name":"Garden \u0026 Industrial","country_code":"BH","province_code":"Money Market Account"}]},{"id":9142748602953836375,"email":"Marvin.Deckow8@hotmail.com","accepts_marketing":false,"created_at":"2020-09-15T12:05:59.4704658+01:00","updated_at":"2020-09-16T07:54:40.3380201+01:00","first_name":"Jayne","last_name":"Fay","orders_count":-451911577,"state":"Rhode Island","total_spent":"Licensed Plastic Towels","last_order_id":-4013631379314488377,"note":"Incredible Plastic Chips","verified_email":false,"multipass_identifier":"Incredible Concrete Towels","tax_exempt":true,"tags":"Paradigm","last_order_name":"Practical Steel Chips","default_address":{"first_name":"Deon","address1":"Andres Mission","phone":"metrics","city":"South Ramon","zip":"applications","province":null,"country":"Hungary","last_name":"Stamm","address2":null,"company":"copy","latitude":0.4337772,"longitude":0.84121877,"name":"Dominican Republic","country_code":"PG","province_code":"Internal"},"addresses":[{"first_name":"Vita","address1":"Architect","phone":"deposit","city":"Port Destineyberg","zip":"Monitored","province":"Practical Frozen Shirt","country":"Palestinian Territory","last_name":"Graham","address2":"Planner","company":"Tasty Granite Pants","latitude":0.3103215,"longitude":0.7323857,"name":"Shoes","country_code":"GA","province_code":"Lead"},{"first_name":"Theresa","address1":"invoice","phone":"grey","city":"West Edgardoshire","zip":"South Dakota","province":"plum","country":"Isle of Man","last_name":"Sanford","address2":"Handmade","company":"circuit","latitude":0.3985035,"longitude":0.439211,"name":"Unbranded","country_code":"ZW","province_code":"Groves"},{"first_name":"Eloisa","address1":"digital","phone":"Texas","city":"Lake Jasperville","zip":"Mississippi","province":"withdrawal","country":"Dominica","last_name":"Weimann","address2":"Face to face","company":"Officer","latitude":0.054001667,"longitude":0.11059718,"name":"generate","country_code":"KZ","province_code":"turquoise"},{"first_name":"Deon","address1":"Andres Mission","phone":"metrics","city":"South Ramon","zip":"applications","province":null,"country":"Hungary","last_name":"Stamm","address2":null,"company":"copy","latitude":0.4337772,"longitude":0.84121877,"name":"Dominican Republic","country_code":"PG","province_code":"Internal"}]},{"id":6250382487629559542,"email":"Joey5@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T16:30:37.1200576+01:00","updated_at":"2020-09-16T08:16:11.2799211+01:00","first_name":"Aglae","last_name":"Orn","orders_count":-85991279,"state":"Virginia","total_spent":"AGP","last_order_id":1671979208028986203,"note":"Mauritania","verified_email":false,"multipass_identifier":"foreground","tax_exempt":false,"tags":"revolutionize","last_order_name":"strategy","default_address":{"first_name":"Mary","address1":"Macejkovic Street","phone":"redundant","city":"Millsmouth","zip":"users","province":null,"country":"Liechtenstein","last_name":"Dickinson","address2":null,"company":"Holy See (Vatican City State)","latitude":0.68988997,"longitude":0.4060322,"name":"override","country_code":"SG","province_code":"Money Market Account"},"addresses":[{"first_name":"Ibrahim","address1":"Assistant","phone":"Officer","city":"New Arvillaside","zip":"Planner","province":"Canada","country":"Macedonia","last_name":"Beatty","address2":"invoice","company":"EXE","latitude":0.08336135,"longitude":0.16830532,"name":"parsing","country_code":"MH","province_code":"Tasty Cotton Shoes"},{"first_name":"Mittie","address1":"haptic","phone":"enable","city":"Ramonton","zip":"synergistic","province":"Awesome Soft Shoes","country":"Bermuda","last_name":"O\u0027Keefe","address2":"Licensed Wooden Car","company":"Avon","latitude":0.48556745,"longitude":0.1708666,"name":"Borders","country_code":"IM","province_code":"payment"},{"first_name":"Tyreek","address1":"attitude-oriented","phone":"Bedfordshire","city":"Mannton","zip":"function","province":"Licensed Steel Cheese","country":"Azerbaijan","last_name":"Bruen","address2":"Home Loan Account","company":"connecting","latitude":0.9968176,"longitude":0.32855573,"name":"application","country_code":"VU","province_code":"Gorgeous"},{"first_name":"Mary","address1":"Macejkovic Street","phone":"redundant","city":"Millsmouth","zip":"users","province":null,"country":"Liechtenstein","last_name":"Dickinson","address2":null,"company":"Holy See (Vatican City State)","latitude":0.68988997,"longitude":0.4060322,"name":"override","country_code":"SG","province_code":"Money Market Account"}]},{"id":-4145781372680763050,"email":"Terry.Tremblay@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T12:18:01.5044804+01:00","updated_at":"2020-09-15T21:31:27.028365+01:00","first_name":"Meagan","last_name":"Doyle","orders_count":87892120,"state":"Arizona","total_spent":"e-enable","last_order_id":-462526621754490707,"note":"Outdoors, Computers \u0026 Sports","verified_email":true,"multipass_identifier":"Incredible Granite Pizza","tax_exempt":false,"tags":"Frozen","last_order_name":"invoice","default_address":{"first_name":"Stacy","address1":"Beatty Well","phone":"Awesome Granite Bike","city":"East Judge","zip":"Ergonomic","province":null,"country":"Hungary","last_name":"Cummerata","address2":null,"company":"Rustic Plastic Cheese","latitude":0.44695026,"longitude":0.19814257,"name":"Arkansas","country_code":"TO","province_code":"Future"},"addresses":[{"first_name":"Leopoldo","address1":"connecting","phone":"action-items","city":"Rosieton","zip":"calculating","province":"Peru","country":"Libyan Arab Jamahiriya","last_name":"Jerde","address2":"payment","company":"FTP","latitude":0.6310803,"longitude":0.66749024,"name":"open-source","country_code":"CO","province_code":"24/7"},{"first_name":"Rosella","address1":"Senegal","phone":"Dobra","city":"East Yasmeen","zip":"Handcrafted Granite Hat","province":"Nebraska","country":"Oman","last_name":"Runte","address2":"Convertible Marks","company":"Licensed Cotton Pizza","latitude":0.5788947,"longitude":0.7148944,"name":"driver","country_code":"PK","province_code":"Tasty Fresh Sausages"},{"first_name":"Ewell","address1":"Cambridgeshire","phone":"optimal","city":"Deondreborough","zip":"Credit Card Account","province":"copying","country":"Latvia","last_name":"Hermann","address2":"content","company":"Analyst","latitude":0.4177854,"longitude":0.20900653,"name":"redundant","country_code":"GQ","province_code":"compressing"},{"first_name":"Stacy","address1":"Beatty Well","phone":"Awesome Granite Bike","city":"East Judge","zip":"Ergonomic","province":null,"country":"Hungary","last_name":"Cummerata","address2":null,"company":"Rustic Plastic Cheese","latitude":0.44695026,"longitude":0.19814257,"name":"Arkansas","country_code":"TO","province_code":"Future"}]},{"id":-7404308370875925026,"email":"Sonia_Schmitt77@gmail.com","accepts_marketing":true,"created_at":"2020-09-15T21:38:09.4910452+01:00","updated_at":"2020-09-15T11:44:04.9961095+01:00","first_name":"Macy","last_name":"Grady","orders_count":-1210999266,"state":"Louisiana","total_spent":"New Mexico","last_order_id":7202466451425897532,"note":"HDD","verified_email":false,"multipass_identifier":"Handcrafted Concrete Car","tax_exempt":false,"tags":"online","last_order_name":"tan","default_address":{"first_name":"Keon","address1":"Gulgowski Place","phone":"protocol","city":"Ankundingtown","zip":"deposit","province":"New York","country":"Guernsey","last_name":"Bergstrom","address2":null,"company":"Supervisor","latitude":0.674163,"longitude":0.111408666,"name":"Kids","country_code":"DJ","province_code":"Human"},"addresses":[{"first_name":"Lue","address1":"panel","phone":"infomediaries","city":"West Wainobury","zip":"intermediate","province":"RAM","country":"Comoros","last_name":"Funk","address2":"Union","company":"monitoring","latitude":0.63785017,"longitude":0.50409776,"name":"Borders","country_code":"BM","province_code":"Nevada"},{"first_name":"Esteban","address1":"viral","phone":"object-oriented","city":"Lake Jo","zip":"cyan","province":"Officer","country":"Gabon","last_name":"Bernhard","address2":"transmitting","company":"back up","latitude":0.9023259,"longitude":0.13310957,"name":"Stravenue","country_code":"PG","province_code":"Representative"},{"first_name":"Clint","address1":"navigating","phone":"Practical","city":"Carmelview","zip":"Mission","province":"blockchains","country":"Algeria","last_name":"Spencer","address2":"Montenegro","company":"viral","latitude":0.5915619,"longitude":0.19958717,"name":"Borders","country_code":"CU","province_code":"Operations"},{"first_name":"Keon","address1":"Gulgowski Place","phone":"protocol","city":"Ankundingtown","zip":"deposit","province":"New York","country":"Guernsey","last_name":"Bergstrom","address2":null,"company":"Supervisor","latitude":0.674163,"longitude":0.111408666,"name":"Kids","country_code":"DJ","province_code":"Human"}]},{"id":2059279224155926894,"email":"Edna.Larson36@gmail.com","accepts_marketing":true,"created_at":"2020-09-15T12:48:12.4358945+01:00","updated_at":"2020-09-16T02:07:33.5990906+01:00","first_name":"Lisa","last_name":"Gislason","orders_count":-2087364998,"state":"Massachusetts","total_spent":"deliverables","last_order_id":-1595722261221489019,"note":"Louisiana","verified_email":false,"multipass_identifier":"Berkshire","tax_exempt":false,"tags":"disintermediate","last_order_name":"asymmetric","default_address":{"first_name":"Ray","address1":"Smith Avenue","phone":"cyan","city":"Cronaview","zip":"Customer","province":null,"country":"Angola","last_name":"Harris","address2":null,"company":"Rubber","latitude":0.9285142,"longitude":0.76574653,"name":"Cape Verde Escudo","country_code":"SH","province_code":"haptic"},"addresses":[{"first_name":"Christian","address1":"Planner","phone":"copy","city":"South Pearlville","zip":"extensible","province":"transmit","country":"Finland","last_name":"Turcotte","address2":"redefine","company":"solid state","latitude":0.15812612,"longitude":0.9555049,"name":"Checking Account","country_code":"LT","province_code":"encoding"},{"first_name":"Foster","address1":"Branding","phone":"port","city":"Reingerstad","zip":"Macao","province":"Ergonomic Fresh Shirt","country":"Serbia","last_name":"Kunze","address2":"systematic","company":"Liberian Dollar","latitude":0.6959884,"longitude":0.086468086,"name":"Mount","country_code":"UG","province_code":"Crest"},{"first_name":"Abraham","address1":"Islands","phone":"Awesome","city":"Sybleberg","zip":"Technician","province":"primary","country":"Seychelles","last_name":"Doyle","address2":"Crescent","company":"alarm","latitude":0.18514743,"longitude":0.3743339,"name":"transitional","country_code":"BA","province_code":"USB"},{"first_name":"Ray","address1":"Smith Avenue","phone":"cyan","city":"Cronaview","zip":"Customer","province":null,"country":"Angola","last_name":"Harris","address2":null,"company":"Rubber","latitude":0.9285142,"longitude":0.76574653,"name":"Cape Verde Escudo","country_code":"SH","province_code":"haptic"}]},{"id":-6952803953763065189,"email":"Lonnie_Roberts31@hotmail.com","accepts_marketing":true,"created_at":"2020-09-16T09:04:45.2177232+01:00","updated_at":"2020-09-15T14:30:54.7197673+01:00","first_name":"Leland","last_name":"Jerde","orders_count":-1900127725,"state":"Texas","total_spent":"sexy","last_order_id":-581234355320520557,"note":"communities","verified_email":true,"multipass_identifier":"unleash","tax_exempt":true,"tags":"Buckinghamshire","last_order_name":"Director","default_address":{"first_name":"Rosanna","address1":"Danial Manor","phone":"override","city":"New Rogelio","zip":"salmon","province":null,"country":"United Arab Emirates","last_name":"Rutherford","address2":null,"company":"Cotton","latitude":0.57305825,"longitude":0.5055677,"name":"Tactics","country_code":"BI","province_code":"Steel"},"addresses":[{"first_name":"Brennan","address1":"Small","phone":"white","city":"West Harleystad","zip":"disintermediate","province":"FTP","country":"Honduras","last_name":"Funk","address2":"USB","company":"Trinidad and Tobago","latitude":0.9313641,"longitude":0.42102107,"name":"integrated","country_code":"AO","province_code":"Manager"},{"first_name":"Nova","address1":"Bahrain","phone":"Cliff","city":"North Tremaine","zip":"cyan","province":"Netherlands","country":"Solomon Islands","last_name":"Huel","address2":"installation","company":"Rustic Fresh Car","latitude":0.83862025,"longitude":0.8105574,"name":"fuchsia","country_code":"VU","province_code":"Isle of Man"},{"first_name":"Rafael","address1":"User-centric","phone":"navigating","city":"Juliannefort","zip":"Handmade Granite Bike","province":"disintermediate","country":"Equatorial Guinea","last_name":"Marvin","address2":"Electronics \u0026 Games","company":"salmon","latitude":0.4239136,"longitude":0.9260285,"name":"Manager","country_code":"AF","province_code":"Ways"},{"first_name":"Rosanna","address1":"Danial Manor","phone":"override","city":"New Rogelio","zip":"salmon","province":null,"country":"United Arab Emirates","last_name":"Rutherford","address2":null,"company":"Cotton","latitude":0.57305825,"longitude":0.5055677,"name":"Tactics","country_code":"BI","province_code":"Steel"}]},{"id":1936072005539118636,"email":"Lynne.Gutmann@yahoo.com","accepts_marketing":false,"created_at":"2020-09-16T00:59:41.0606132+01:00","updated_at":"2020-09-16T03:56:13.5622202+01:00","first_name":"Anjali","last_name":"Berge","orders_count":-1427231080,"state":"New Mexico","total_spent":"Savings Account","last_order_id":6726837873015061978,"note":"Bedfordshire","verified_email":false,"multipass_identifier":"Money Market Account","tax_exempt":true,"tags":"Home","last_order_name":"program","default_address":{"first_name":"Eva","address1":"Sauer Mission","phone":"Unbranded","city":"Port Dariotown","zip":"Operations","province":"Georgia","country":"Sri Lanka","last_name":"Nienow","address2":null,"company":"out-of-the-box","latitude":0.8123123,"longitude":0.36280498,"name":"generate","country_code":"CO","province_code":"Way"},"addresses":[{"first_name":"Bernice","address1":"bifurcated","phone":"District","city":"Marvinbury","zip":"Trafficway","province":"customer loyalty","country":"Bosnia and Herzegovina","last_name":"Lindgren","address2":"invoice","company":"transmit","latitude":0.98601633,"longitude":0.2883084,"name":"Security","country_code":"AD","province_code":"firewall"},{"first_name":"Deron","address1":"Toys \u0026 Health","phone":"static","city":"Traceyfort","zip":"Home Loan Account","province":"1080p","country":"Mexico","last_name":"Carroll","address2":"Mission","company":"Investor","latitude":0.58929616,"longitude":0.697291,"name":"Track","country_code":"MD","province_code":"cutting-edge"},{"first_name":"Ila","address1":"morph","phone":"bluetooth","city":"South Emmamouth","zip":"AGP","province":"Auto Loan Account","country":"Oman","last_name":"Wyman","address2":"invoice","company":"Congolese Franc","latitude":0.9014443,"longitude":0.04548067,"name":"Concrete","country_code":"PF","province_code":"deposit"},{"first_name":"Eva","address1":"Sauer Mission","phone":"Unbranded","city":"Port Dariotown","zip":"Operations","province":"Georgia","country":"Sri Lanka","last_name":"Nienow","address2":null,"company":"out-of-the-box","latitude":0.8123123,"longitude":0.36280498,"name":"generate","country_code":"CO","province_code":"Way"}]},{"id":-2683122528405737335,"email":"Ramon.Larkin26@yahoo.com","accepts_marketing":true,"created_at":"2020-09-15T12:48:38.6150595+01:00","updated_at":"2020-09-15T20:55:49.7052206+01:00","first_name":"Florine","last_name":"Jakubowski","orders_count":-2033482603,"state":"New York","total_spent":"Assurance","last_order_id":3783437830974539089,"note":"digital","verified_email":true,"multipass_identifier":"structure","tax_exempt":true,"tags":"bypass","last_order_name":"static","default_address":{"first_name":"Emanuel","address1":"Jayce Forge","phone":"GB","city":"East Mayfurt","zip":"content","province":"Colorado","country":"Saint Martin","last_name":"Walter","address2":null,"company":"maximized","latitude":0.98189783,"longitude":0.97940683,"name":"Liaison","country_code":"VG","province_code":"bus"},"addresses":[{"first_name":"Diego","address1":"Burgs","phone":"Ergonomic Plastic Shoes","city":"West Adolfoburgh","zip":"next-generation","province":"portals","country":"Greece","last_name":"Schaden","address2":"overriding","company":"copying","latitude":0.6332553,"longitude":0.14480044,"name":"Future","country_code":"CY","province_code":"Programmable"},{"first_name":"Enoch","address1":"Intelligent Rubber Hat","phone":"Park","city":"Port Jaymeborough","zip":"multi-state","province":"gold","country":"Sweden","last_name":"Turcotte","address2":"Handmade Steel Computer","company":"Gorgeous Concrete Fish","latitude":0.712408,"longitude":0.011186156,"name":"scalable","country_code":"RW","province_code":"challenge"},{"first_name":"Heber","address1":"program","phone":"Supervisor","city":"Jerroldview","zip":"Village","province":"Kip","country":"Armenia","last_name":"Graham","address2":"Chile","company":"Avon","latitude":0.4484028,"longitude":0.47039255,"name":"bypassing","country_code":"PG","province_code":"Cambridgeshire"},{"first_name":"Emanuel","address1":"Jayce Forge","phone":"GB","city":"East Mayfurt","zip":"content","province":"Colorado","country":"Saint Martin","last_name":"Walter","address2":null,"company":"maximized","latitude":0.98189783,"longitude":0.97940683,"name":"Liaison","country_code":"VG","province_code":"bus"}]},{"id":5245656149043751113,"email":"Cindy41@gmail.com","accepts_marketing":true,"created_at":"2020-09-16T10:22:58.6017189+01:00","updated_at":"2020-09-16T02:51:57.3530081+01:00","first_name":"Maurine","last_name":"White","orders_count":-155460620,"state":"Alabama","total_spent":"Ergonomic","last_order_id":-2475352488932576489,"note":"parse","verified_email":false,"multipass_identifier":"Applications","tax_exempt":true,"tags":"Practical Cotton Chips","last_order_name":"ability","default_address":{"first_name":"Dayana","address1":"Fern Harbor","phone":"Gorgeous Concrete Towels","city":"Delbertshire","zip":"e-commerce","province":null,"country":"Austria","last_name":"Bayer","address2":"Scot Island","company":"Grocery \u0026 Clothing","latitude":0.86461926,"longitude":0.86952275,"name":"Assurance","country_code":"BS","province_code":"Quality"},"addresses":[{"first_name":"Jayne","address1":"hard drive","phone":"Incredible","city":"Lupestad","zip":"solution-oriented","province":"Gorgeous Frozen Gloves","country":"Lithuania","last_name":"Altenwerth","address2":"pink","company":"programming","latitude":0.79655516,"longitude":0.8651653,"name":"Buckinghamshire","country_code":"ER","province_code":"generating"},{"first_name":"Ellie","address1":"Personal Loan Account","phone":"conglomeration","city":"North Kaylieburgh","zip":"Burgs","province":"systematic","country":"Somalia","last_name":"Erdman","address2":"Innovative","company":"Credit Card Account","latitude":0.2040986,"longitude":0.97046894,"name":"virtual","country_code":"NP","province_code":"payment"},{"first_name":"Leann","address1":"Chief","phone":"Applications","city":"South Harold","zip":"platforms","province":"red","country":"Libyan Arab Jamahiriya","last_name":"Ankunding","address2":"Plastic","company":"indexing","latitude":0.23298281,"longitude":0.6233208,"name":"District","country_code":"CH","province_code":"Unbranded Granite Car"},{"first_name":"Dayana","address1":"Fern Harbor","phone":"Gorgeous Concrete Towels","city":"Delbertshire","zip":"e-commerce","province":null,"country":"Austria","last_name":"Bayer","address2":"Scot Island","company":"Grocery \u0026 Clothing","latitude":0.86461926,"longitude":0.86952275,"name":"Assurance","country_code":"BS","province_code":"Quality"}]},{"id":4190575210129257289,"email":"Anna_Cormier75@gmail.com","accepts_marketing":true,"created_at":"2020-09-15T14:14:09.7940409+01:00","updated_at":"2020-09-16T05:05:59.9125687+01:00","first_name":"Cecelia","last_name":"Larson","orders_count":613703456,"state":"North Dakota","total_spent":"COM","last_order_id":-716783849662919014,"note":"complexity","verified_email":false,"multipass_identifier":"index","tax_exempt":true,"tags":"initiatives","last_order_name":"Sleek Plastic Pants","default_address":{"first_name":"Selena","address1":"Schowalter Lock","phone":"Tools \u0026 Industrial","city":"Lake Candicefort","zip":"supply-chains","province":null,"country":"French Southern Territories","last_name":"Wiza","address2":"Jacobs Course","company":"Frozen","latitude":0.43007714,"longitude":0.7519039,"name":"optical","country_code":"LI","province_code":"open-source"},"addresses":[{"first_name":"Geovanny","address1":"out-of-the-box","phone":"black","city":"North Arvelhaven","zip":"magenta","province":"Configurable","country":"Turkmenistan","last_name":"Bartoletti","address2":"override","company":"Practical","latitude":0.85112715,"longitude":0.11866791,"name":"Checking Account","country_code":"US","province_code":"Heights"},{"first_name":"Shany","address1":"out-of-the-box","phone":"Rubber","city":"Fayeborough","zip":"1080p","province":"Investment Account","country":"Netherlands Antilles","last_name":"Oberbrunner","address2":"index","company":"envisioneer","latitude":0.041187346,"longitude":0.83521014,"name":"SMTP","country_code":"NE","province_code":"quantify"},{"first_name":"Wiley","address1":"superstructure","phone":"turquoise","city":"Princesshaven","zip":"efficient","province":"array","country":"Wallis and Futuna","last_name":"Upton","address2":"Villages","company":"Common","latitude":0.750007,"longitude":0.8781609,"name":"Toys, Baby \u0026 Books","country_code":"IQ","province_code":"bypassing"},{"first_name":"Selena","address1":"Schowalter Lock","phone":"Tools \u0026 Industrial","city":"Lake Candicefort","zip":"supply-chains","province":null,"country":"French Southern Territories","last_name":"Wiza","address2":"Jacobs Course","company":"Frozen","latitude":0.43007714,"longitude":0.7519039,"name":"optical","country_code":"LI","province_code":"open-source"}]},{"id":6850401436478675240,"email":"Maryann.Kilback70@yahoo.com","accepts_marketing":true,"created_at":"2020-09-15T12:08:27.6944501+01:00","updated_at":"2020-09-15T23:56:28.4092684+01:00","first_name":"Darion","last_name":"Koepp","orders_count":-1475244603,"state":"Alaska","total_spent":"Group","last_order_id":3588482685428410804,"note":"middleware","verified_email":true,"multipass_identifier":"Bedfordshire","tax_exempt":false,"tags":"monitoring","last_order_name":"Bermuda","default_address":{"first_name":"Dayton","address1":"Cristian Vista","phone":"Fantastic Granite Shoes","city":"West Cody","zip":"eyeballs","province":null,"country":"Germany","last_name":"Pagac","address2":null,"company":"matrix","latitude":0.22589298,"longitude":0.7634811,"name":"CSS","country_code":"SG","province_code":"XML"},"addresses":[{"first_name":"Amy","address1":"alarm","phone":"Saudi Riyal","city":"Marjolaineton","zip":"open architecture","province":"Pre-emptive","country":"Australia","last_name":"Grimes","address2":"Ville","company":"Sleek Granite Fish","latitude":0.36314172,"longitude":0.82922107,"name":"withdrawal","country_code":"CM","province_code":"Home Loan Account"},{"first_name":"Meggie","address1":"Florida","phone":"Orchestrator","city":"West Weston","zip":"Auto Loan Account","province":"calculate","country":"Guatemala","last_name":"Pfeffer","address2":"Wooden","company":"Tactics","latitude":0.6580688,"longitude":0.9491088,"name":"fuchsia","country_code":"MM","province_code":"Ergonomic"},{"first_name":"Beau","address1":"Incredible Frozen Fish","phone":"Czech Republic","city":"Aldahaven","zip":"programming","province":"Street","country":"Mongolia","last_name":"Mohr","address2":"copying","company":"deposit","latitude":0.6859979,"longitude":0.830916,"name":"AI","country_code":"BG","province_code":"conglomeration"},{"first_name":"Dayton","address1":"Cristian Vista","phone":"Fantastic Granite Shoes","city":"West Cody","zip":"eyeballs","province":null,"country":"Germany","last_name":"Pagac","address2":null,"company":"matrix","latitude":0.22589298,"longitude":0.7634811,"name":"CSS","country_code":"SG","province_code":"XML"}]},{"id":-1675632584522080215,"email":"Casey58@gmail.com","accepts_marketing":false,"created_at":"2020-09-15T20:41:15.5766558+01:00","updated_at":"2020-09-16T04:07:04.3701625+01:00","first_name":"Rusty","last_name":"Toy","orders_count":-1277451707,"state":"Colorado","total_spent":"COM","last_order_id":-6870144739722615375,"note":"COM","verified_email":false,"multipass_identifier":"Bedfordshire","tax_exempt":false,"tags":"invoice","last_order_name":"Common","default_address":{"first_name":"Crawford","address1":"Oberbrunner Road","phone":"revolutionary","city":"East Dominic","zip":"bluetooth","province":null,"country":"Burundi","last_name":"Keeling","address2":"Shanel Wells","company":"RAM","latitude":0.23748423,"longitude":0.31530336,"name":"overriding","country_code":"GN","province_code":"HTTP"},"addresses":[{"first_name":"Heidi","address1":"transmitting","phone":"Ameliorated","city":"Boylestad","zip":"Unbranded Fresh Salad","province":"deposit","country":"Singapore","last_name":"Swaniawski","address2":"Intranet","company":"Awesome","latitude":0.4733653,"longitude":0.14200513,"name":"optical","country_code":"SX","province_code":"navigating"},{"first_name":"Junius","address1":"Pitcairn Islands","phone":"COM","city":"Barrowsfurt","zip":"Tasty Wooden Car","province":"lime","country":"Malta","last_name":"Champlin","address2":"Wells","company":"Savings Account","latitude":0.22747725,"longitude":0.37987113,"name":"protocol","country_code":"FM","province_code":"Ergonomic Frozen Mouse"},{"first_name":"Maryjane","address1":"Unbranded","phone":"initiatives","city":"New Theodoratown","zip":"compressing","province":"Yen","country":"Niue","last_name":"Williamson","address2":"payment","company":"United States of America","latitude":0.7862778,"longitude":0.1377169,"name":"Checking Account","country_code":"AQ","province_code":"Arizona"},{"first_name":"Crawford","address1":"Oberbrunner Road","phone":"revolutionary","city":"East Dominic","zip":"bluetooth","province":null,"country":"Burundi","last_name":"Keeling","address2":"Shanel Wells","company":"RAM","latitude":0.23748423,"longitude":0.31530336,"name":"overriding","country_code":"GN","province_code":"HTTP"}]},{"id":-7274904923197369690,"email":"Julia50@yahoo.com","accepts_marketing":false,"created_at":"2020-09-16T03:20:06.6202717+01:00","updated_at":"2020-09-16T06:07:04.1003052+01:00","first_name":"Leatha","last_name":"Considine","orders_count":419006615,"state":"Texas","total_spent":"drive","last_order_id":5916053746297871900,"note":"knowledge user","verified_email":false,"multipass_identifier":"withdrawal","tax_exempt":false,"tags":"Lane","last_order_name":"maroon","default_address":{"first_name":"Monique","address1":"Joanie Harbor","phone":"Kiribati","city":"Roxannefort","zip":"withdrawal","province":null,"country":"Austria","last_name":"Satterfield","address2":null,"company":"azure","latitude":0.66156954,"longitude":0.5667123,"name":"maximize","country_code":"PF","province_code":"Unbranded Fresh Shirt"},"addresses":[{"first_name":"Maynard","address1":"Ergonomic","phone":"cross-platform","city":"Kozeyburgh","zip":"relationships","province":"Small Plastic Pants","country":"Poland","last_name":"Rice","address2":"Kwanza","company":"SAS","latitude":0.6828476,"longitude":0.12563054,"name":"circuit","country_code":"KZ","province_code":"olive"},{"first_name":"Alana","address1":"mission-critical","phone":"interactive","city":"New Vidaland","zip":"Quality-focused","province":"generate","country":"Montserrat","last_name":"Beer","address2":"Customer","company":"Electronics","latitude":0.57863486,"longitude":0.7976103,"name":"American Samoa","country_code":"IL","province_code":"incentivize"},{"first_name":"Greyson","address1":"transmitter","phone":"extend","city":"Shaynetown","zip":"Frozen","province":"drive","country":"Kyrgyz Republic","last_name":"Pollich","address2":"Common","company":"viral","latitude":0.51694685,"longitude":0.7228666,"name":"Ways","country_code":"GF","province_code":"Guatemala"},{"first_name":"Monique","address1":"Joanie Harbor","phone":"Kiribati","city":"Roxannefort","zip":"withdrawal","province":null,"country":"Austria","last_name":"Satterfield","address2":null,"company":"azure","latitude":0.66156954,"longitude":0.5667123,"name":"maximize","country_code":"PF","province_code":"Unbranded Fresh Shirt"}]},{"id":-8893649261403123115,"email":"Krystal_Kohler58@gmail.com","accepts_marketing":true,"created_at":"2020-09-15T18:48:27.937851+01:00","updated_at":"2020-09-16T10:12:48.6817742+01:00","first_name":"Celia","last_name":"Dietrich","orders_count":-123070480,"state":"Massachusetts","total_spent":"PNG","last_order_id":-4165507212587679430,"note":"Streamlined","verified_email":false,"multipass_identifier":"haptic","tax_exempt":false,"tags":"index","last_order_name":"Bedfordshire","default_address":{"first_name":"Nicola","address1":"Hettinger Tunnel","phone":"mobile","city":"East Casimermouth","zip":"Heard Island and McDonald Islands","province":"Louisiana","country":"Macao","last_name":"Pacocha","address2":null,"company":"Tasty Cotton Shoes","latitude":0.35784686,"longitude":0.6860319,"name":"Usability","country_code":"KZ","province_code":"high-level"},"addresses":[{"first_name":"Eleazar","address1":"Berkshire","phone":"Licensed Cotton Gloves","city":"South Amelie","zip":"Turnpike","province":"Refined","country":"Egypt","last_name":"Kemmer","address2":"hack","company":"deposit","latitude":0.79412085,"longitude":0.4065832,"name":"strategy","country_code":"TF","province_code":"Borders"},{"first_name":"Dereck","address1":"Future","phone":"Yemeni Rial","city":"Flatleymouth","zip":"Investment Account","province":"radical","country":"Macedonia","last_name":"Ondricka","address2":"hack","company":"Avon","latitude":0.035242695,"longitude":0.6104903,"name":"Expanded","country_code":"TF","province_code":"Turks and Caicos Islands"},{"first_name":"Adalberto","address1":"relationships","phone":"Auto Loan Account","city":"Tremblaystad","zip":"Licensed","province":"Kids, Books \u0026 Electronics","country":"Saint Pierre and Miquelon","last_name":"Jacobson","address2":"Sports","company":"Savings Account","latitude":0.98281926,"longitude":0.5327853,"name":"transmitter","country_code":"LC","province_code":"Cambridgeshire"},{"first_name":"Nicola","address1":"Hettinger Tunnel","phone":"mobile","city":"East Casimermouth","zip":"Heard Island and McDonald Islands","province":"Louisiana","country":"Macao","last_name":"Pacocha","address2":null,"company":"Tasty Cotton Shoes","latitude":0.35784686,"longitude":0.6860319,"name":"Usability","country_code":"KZ","province_code":"high-level"}]},{"id":9106794478219539022,"email":"Gwendolyn57@gmail.com","accepts_marketing":true,"created_at":"2020-09-15T19:02:03.352988+01:00","updated_at":"2020-09-16T05:15:25.0506018+01:00","first_name":"Green","last_name":"Schulist","orders_count":-1321777314,"state":"Montana","total_spent":"Ergonomic Wooden Chicken","last_order_id":6499376456452592230,"note":"Palestinian Territory","verified_email":true,"multipass_identifier":"empowering","tax_exempt":true,"tags":"fuchsia","last_order_name":"sky blue","default_address":{"first_name":"Rosalinda","address1":"Georgianna Mountains","phone":"invoice","city":"Robertsview","zip":"microchip","province":null,"country":"Lebanon","last_name":"Greenfelder","address2":null,"company":"Granite","latitude":0.7267875,"longitude":0.7269627,"name":"Expanded","country_code":"BZ","province_code":"reboot"},"addresses":[{"first_name":"Agnes","address1":"payment","phone":"bifurcated","city":"Lake Gustaveville","zip":"internet solution","province":"AI","country":"Yemen","last_name":"Ziemann","address2":"web-readiness","company":"virtual","latitude":0.9506839,"longitude":0.9010537,"name":"Soft","country_code":"CK","province_code":"Liaison"},{"first_name":"Naomie","address1":"transmitting","phone":"black","city":"South Mallieborough","zip":"COM","province":"Web","country":"Cuba","last_name":"Auer","address2":"Re-contextualized","company":"deposit","latitude":0.8595085,"longitude":0.34855583,"name":"Future","country_code":"AU","province_code":"Dale"},{"first_name":"Woodrow","address1":"Investment Account","phone":"Credit Card Account","city":"West Bradly","zip":"AGP","province":"installation","country":"Ireland","last_name":"Wisozk","address2":"Louisiana","company":"Road","latitude":0.8301273,"longitude":0.7969527,"name":"Strategist","country_code":"IR","province_code":"e-markets"},{"first_name":"Rosalinda","address1":"Georgianna Mountains","phone":"invoice","city":"Robertsview","zip":"microchip","province":null,"country":"Lebanon","last_name":"Greenfelder","address2":null,"company":"Granite","latitude":0.7267875,"longitude":0.7269627,"name":"Expanded","country_code":"BZ","province_code":"reboot"}]},{"id":7793314597121736080,"email":"Kristen.Smitham@yahoo.com","accepts_marketing":true,"created_at":"2020-09-15T17:34:23.2162113+01:00","updated_at":"2020-09-16T10:10:42.8632879+01:00","first_name":"Lenora","last_name":"Glover","orders_count":1022032451,"state":"Louisiana","total_spent":"backing up","last_order_id":-2998719190773995735,"note":"Frozen","verified_email":false,"multipass_identifier":"transmitter","tax_exempt":false,"tags":"enhance","last_order_name":"Tennessee","default_address":{"first_name":"Elouise","address1":"Holden Harbor","phone":"IB","city":"Lake Angelchester","zip":"Factors","province":"Maryland","country":"Wallis and Futuna","last_name":"Kuhn","address2":null,"company":"virtual","latitude":0.89429015,"longitude":0.46682656,"name":"multi-byte","country_code":"GQ","province_code":"Rustic"},"addresses":[{"first_name":"Jedediah","address1":"calculating","phone":"backing up","city":"Glenland","zip":"incentivize","province":"PCI","country":"Kenya","last_name":"Zboncak","address2":"ubiquitous","company":"Incredible Granite Car","latitude":0.8884326,"longitude":0.9796302,"name":"Steel","country_code":"RS","province_code":"calculating"},{"first_name":"Wendell","address1":"Small","phone":"secondary","city":"South Eveline","zip":"Wooden","province":"transmit","country":"Guernsey","last_name":"Hane","address2":"Accountability","company":"grid-enabled","latitude":0.3072096,"longitude":0.22823434,"name":"Central","country_code":"KN","province_code":"clicks-and-mortar"},{"first_name":"Bradley","address1":"Movies, Shoes \u0026 Shoes","phone":"copying","city":"West Martina","zip":"Metal","province":"quantifying","country":"Albania","last_name":"Weissnat","address2":"Cambridgeshire","company":"hub","latitude":0.79869473,"longitude":0.6897794,"name":"ability","country_code":"NL","province_code":"Bedfordshire"},{"first_name":"Elouise","address1":"Holden Harbor","phone":"IB","city":"Lake Angelchester","zip":"Factors","province":"Maryland","country":"Wallis and Futuna","last_name":"Kuhn","address2":null,"company":"virtual","latitude":0.89429015,"longitude":0.46682656,"name":"multi-byte","country_code":"GQ","province_code":"Rustic"}]},{"id":2894480789718079205,"email":"Israel_Langworth32@yahoo.com","accepts_marketing":false,"created_at":"2020-09-15T21:25:36.240432+01:00","updated_at":"2020-09-15T16:49:35.1926682+01:00","first_name":"Adonis","last_name":"Jaskolski","orders_count":-1788543595,"state":"Massachusetts","total_spent":"Hawaii","last_order_id":7292595884907886314,"note":"Savings Account","verified_email":false,"multipass_identifier":"invoice","tax_exempt":true,"tags":"Dobra","last_order_name":"markets","default_address":{"first_name":"Chesley","address1":"Erdman Lakes","phone":"Tools","city":"Kuvalisborough","zip":"protocol","province":null,"country":"Ghana","last_name":"Luettgen","address2":null,"company":"Generic Soft Fish","latitude":0.85351956,"longitude":0.8369192,"name":"Money Market Account","country_code":"GN","province_code":"olive"},"addresses":[{"first_name":"Shakira","address1":"matrix","phone":"Fresh","city":"Marcelotown","zip":"Borders","province":"deposit","country":"Guadeloupe","last_name":"Herman","address2":"help-desk","company":"SSL","latitude":0.1472305,"longitude":0.04175925,"name":"Croatian Kuna","country_code":"GN","province_code":"Island"},{"first_name":"Chanel","address1":"haptic","phone":"focus group","city":"New Osvaldoland","zip":"primary","province":"International","country":"Madagascar","last_name":"Treutel","address2":"systematic","company":"Concrete","latitude":0.9447714,"longitude":0.6927103,"name":"GB","country_code":"GB","province_code":"Buckinghamshire"},{"first_name":"Richmond","address1":"Home","phone":"Villages","city":"New Lilianview","zip":"Internal","province":"Light","country":"Northern Mariana Islands","last_name":"Jerde","address2":"Fantastic","company":"synthesizing","latitude":0.04366852,"longitude":0.93451446,"name":"Summit","country_code":"GH","province_code":"Peru"},{"first_name":"Chesley","address1":"Erdman Lakes","phone":"Tools","city":"Kuvalisborough","zip":"protocol","province":null,"country":"Ghana","last_name":"Luettgen","address2":null,"company":"Generic Soft Fish","latitude":0.85351956,"longitude":0.8369192,"name":"Money Market Account","country_code":"GN","province_code":"olive"}]},{"id":-3627246706618086023,"email":"Madeline.Welch11@hotmail.com","accepts_marketing":true,"created_at":"2020-09-16T00:32:39.6053921+01:00","updated_at":"2020-09-16T11:00:46.7088383+01:00","first_name":"Lyric","last_name":"West","orders_count":1095075294,"state":"Tennessee","total_spent":"extend","last_order_id":-1907199826612675360,"note":"Florida","verified_email":false,"multipass_identifier":"Granite","tax_exempt":false,"tags":"e-markets","last_order_name":"Games","default_address":{"first_name":"Brook","address1":"Tyrique Rapids","phone":"zero defect","city":"Schultzfurt","zip":"withdrawal","province":"Nevada","country":"Trinidad and Tobago","last_name":"Lowe","address2":null,"company":"Denmark","latitude":0.8334318,"longitude":0.47363752,"name":"Course","country_code":"AU","province_code":"AGP"},"addresses":[{"first_name":"Fredrick","address1":"deposit","phone":"Rue","city":"Bechtelarside","zip":"parsing","province":"Money Market Account","country":"Gabon","last_name":"Kreiger","address2":"Frozen","company":"Pines","latitude":0.802292,"longitude":0.8544218,"name":"magnetic","country_code":"AE","province_code":"strategic"},{"first_name":"Kenna","address1":"disintermediate","phone":"reboot","city":"West Margaretberg","zip":"integrated","province":"Ergonomic Concrete Bike","country":"Dominican Republic","last_name":"Yundt","address2":"Division","company":"Haven","latitude":0.30460635,"longitude":0.2805814,"name":"quantifying","country_code":"BQ","province_code":"capacitor"},{"first_name":"Brock","address1":"Codes specifically reserved for testing purposes","phone":"Integration","city":"Kayleebury","zip":"Iceland Krona","province":"override","country":"Poland","last_name":"Kling","address2":"Cambridgeshire","company":"firewall","latitude":0.03901781,"longitude":0.76185054,"name":"quantifying","country_code":"MU","province_code":"Solutions"},{"first_name":"Brook","address1":"Tyrique Rapids","phone":"zero defect","city":"Schultzfurt","zip":"withdrawal","province":"Nevada","country":"Trinidad and Tobago","last_name":"Lowe","address2":null,"company":"Denmark","latitude":0.8334318,"longitude":0.47363752,"name":"Course","country_code":"AU","province_code":"AGP"}]},{"id":915538168662017917,"email":"Gwendolyn.Cassin19@yahoo.com","accepts_marketing":true,"created_at":"2020-09-16T09:36:26.8045442+01:00","updated_at":"2020-09-16T07:08:23.7292714+01:00","first_name":"Candelario","last_name":"Jenkins","orders_count":-348575885,"state":"Utah","total_spent":"Mall","last_order_id":-5503569364785383100,"note":"Spurs","verified_email":false,"multipass_identifier":"Intelligent Plastic Chair","tax_exempt":true,"tags":"overriding","last_order_name":"synthesize","default_address":{"first_name":"Jodie","address1":"Abshire Way","phone":"Clothing \u0026 Toys","city":"East Celia","zip":"connecting","province":null,"country":"Azerbaijan","last_name":"Haley","address2":null,"company":"bi-directional","latitude":0.31430227,"longitude":0.5409207,"name":"Tasty Fresh Pizza","country_code":"KM","province_code":"Developer"},"addresses":[{"first_name":"Lesly","address1":"Producer","phone":"invoice","city":"Kuhicland","zip":"Branch","province":"Small Frozen Pants","country":"Montserrat","last_name":"Gulgowski","address2":"solid state","company":"Rubber","latitude":0.7510687,"longitude":0.7773698,"name":"Alley","country_code":"UA","province_code":"disintermediate"},{"first_name":"Gustave","address1":"lavender","phone":"deposit","city":"North Kristin","zip":"cultivate","province":"synthesizing","country":"Cape Verde","last_name":"Feil","address2":"invoice","company":"streamline","latitude":0.70774955,"longitude":0.6707658,"name":"Knolls","country_code":"PF","province_code":"Awesome"},{"first_name":"Rosa","address1":"JSON","phone":"firmware","city":"North Friedahaven","zip":"Ferry","province":"Generic Soft Chips","country":"Palau","last_name":"Turcotte","address2":"Coordinator","company":"Lithuania","latitude":0.058293045,"longitude":0.8993201,"name":"SQL","country_code":"MQ","province_code":"program"},{"first_name":"Jodie","address1":"Abshire Way","phone":"Clothing \u0026 Toys","city":"East Celia","zip":"connecting","province":null,"country":"Azerbaijan","last_name":"Haley","address2":null,"company":"bi-directional","latitude":0.31430227,"longitude":0.5409207,"name":"Tasty Fresh Pizza","country_code":"KM","province_code":"Developer"}]},{"id":-8081306284895051812,"email":"Billie.Mueller@gmail.com","accepts_marketing":true,"created_at":"2020-09-16T06:46:26.8000752+01:00","updated_at":"2020-09-15T20:38:16.30462+01:00","first_name":"Peter","last_name":"Strosin","orders_count":1377452109,"state":"Nebraska","total_spent":"neural","last_order_id":-1524712106594770327,"note":"Direct","verified_email":false,"multipass_identifier":"Handmade Plastic Tuna","tax_exempt":false,"tags":"TCP","last_order_name":"Personal Loan Account","default_address":{"first_name":"Anastasia","address1":"Lester Knoll","phone":"Buckinghamshire","city":"Bransonside","zip":"approach","province":null,"country":"Kenya","last_name":"Legros","address2":null,"company":"Mount","latitude":0.5191005,"longitude":0.5097897,"name":"copying","country_code":"JM","province_code":"1080p"},"addresses":[{"first_name":"Christ","address1":"Kentucky","phone":"cross-platform","city":"South Hal","zip":"Estate","province":"District","country":"Liechtenstein","last_name":"Hane","address2":"connecting","company":"haptic","latitude":0.31744212,"longitude":0.9574512,"name":"exploit","country_code":"NF","province_code":"AGP"},{"first_name":"Angie","address1":"Handcrafted Frozen Keyboard","phone":"Clothing \u0026 Garden","city":"New Candacebury","zip":"bypass","province":"orchestrate","country":"Romania","last_name":"Reinger","address2":"embrace","company":"Shoes","latitude":0.7157911,"longitude":0.9086472,"name":"Park","country_code":"ST","province_code":"Investor"},{"first_name":"Robin","address1":"Circles","phone":"Licensed","city":"Hoppestad","zip":"Bolivia","province":"Eritrea","country":"Niue","last_name":"Thompson","address2":"Light","company":"Roads","latitude":0.32208025,"longitude":0.5844536,"name":"Awesome Steel Sausages","country_code":"SX","province_code":"South Carolina"},{"first_name":"Anastasia","address1":"Lester Knoll","phone":"Buckinghamshire","city":"Bransonside","zip":"approach","province":null,"country":"Kenya","last_name":"Legros","address2":null,"company":"Mount","latitude":0.5191005,"longitude":0.5097897,"name":"copying","country_code":"JM","province_code":"1080p"}]},{"id":-547194909827790352,"email":"Nelson86@yahoo.com","accepts_marketing":false,"created_at":"2020-09-16T06:06:50.6874911+01:00","updated_at":"2020-09-15T13:51:23.5317492+01:00","first_name":"Madilyn","last_name":"Labadie","orders_count":-769862100,"state":"Wisconsin","total_spent":"Forward","last_order_id":-7299256434294284587,"note":"International","verified_email":false,"multipass_identifier":"International","tax_exempt":true,"tags":"Investment Account","last_order_name":"Incredible Rubber Chicken","default_address":{"first_name":"German","address1":"Theresia Common","phone":"transmitting","city":"New Hillardland","zip":"transmitter","province":null,"country":"Venezuela","last_name":"Dach","address2":null,"company":"Practical","latitude":0.37303266,"longitude":0.025772044,"name":"Bridge","country_code":"PM","province_code":"PNG"},"addresses":[{"first_name":"Eli","address1":"Mount","phone":"productize","city":"East Larissa","zip":"Direct","province":"back-end","country":"Wallis and Futuna","last_name":"Luettgen","address2":"invoice","company":"solid state","latitude":0.19547556,"longitude":0.46225247,"name":"Forward","country_code":"CI","province_code":"Flat"},{"first_name":"Jayson","address1":"Street","phone":"Ranch","city":"Amparobury","zip":"Movies, Music \u0026 Sports","province":"Awesome","country":"Comoros","last_name":"Mraz","address2":"Sleek Rubber Towels","company":"recontextualize","latitude":0.41294932,"longitude":0.46172673,"name":"SAS","country_code":"SC","province_code":"Rustic Wooden Fish"},{"first_name":"Newton","address1":"Central African Republic","phone":"program","city":"New Donnymouth","zip":"redundant","province":"transmitting","country":"Azerbaijan","last_name":"Roberts","address2":"Personal Loan Account","company":"Refined Soft Fish","latitude":0.036348306,"longitude":0.94429034,"name":"markets","country_code":"EG","province_code":"RAM"},{"first_name":"German","address1":"Theresia Common","phone":"transmitting","city":"New Hillardland","zip":"transmitter","province":null,"country":"Venezuela","last_name":"Dach","address2":null,"company":"Practical","latitude":0.37303266,"longitude":0.025772044,"name":"Bridge","country_code":"PM","province_code":"PNG"}]},{"id":-1214026782281436543,"email":"Mattie_Champlin@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T22:42:50.6273027+01:00","updated_at":"2020-09-15T15:23:25.0157763+01:00","first_name":"Clifton","last_name":"Ondricka","orders_count":975083526,"state":"Georgia","total_spent":"Sleek Steel Pants","last_order_id":7167562781203408701,"note":"Ports","verified_email":true,"multipass_identifier":"International","tax_exempt":true,"tags":"Accounts","last_order_name":"Kyrgyz Republic","default_address":{"first_name":"Orin","address1":"Gibson Views","phone":"Shoes","city":"New Bellfurt","zip":"Borders","province":null,"country":"Niue","last_name":"Waelchi","address2":null,"company":"Credit Card Account","latitude":0.5954465,"longitude":0.90305364,"name":"Borders","country_code":"SC","province_code":"Handcrafted Steel Bacon"},"addresses":[{"first_name":"Sydni","address1":"Advanced","phone":"Home, Tools \u0026 Health","city":"South Jimmy","zip":"Factors","province":"expedite","country":"Montenegro","last_name":"Macejkovic","address2":"Ferry","company":"Senegal","latitude":0.2218679,"longitude":0.16878669,"name":"facilitate","country_code":"BG","province_code":"Euro"},{"first_name":"Trent","address1":"Savings Account","phone":"Auto Loan Account","city":"Sauerland","zip":"whiteboard","province":"Crossing","country":"Oman","last_name":"Harris","address2":"Chile","company":"local area network","latitude":0.59452045,"longitude":0.6031077,"name":"best-of-breed","country_code":"TF","province_code":"Parkway"},{"first_name":"Roman","address1":"Uruguay","phone":"action-items","city":"Kuhnside","zip":"Reactive","province":"synthesize","country":"Vanuatu","last_name":"Bogan","address2":"Incredible Concrete Chair","company":"Mission","latitude":0.3657579,"longitude":0.8808378,"name":"New Taiwan Dollar","country_code":"AW","province_code":"Planner"},{"first_name":"Orin","address1":"Gibson Views","phone":"Shoes","city":"New Bellfurt","zip":"Borders","province":null,"country":"Niue","last_name":"Waelchi","address2":null,"company":"Credit Card Account","latitude":0.5954465,"longitude":0.90305364,"name":"Borders","country_code":"SC","province_code":"Handcrafted Steel Bacon"}]},{"id":-1716311534061419627,"email":"Carroll.Auer96@hotmail.com","accepts_marketing":true,"created_at":"2020-09-16T04:31:06.0525994+01:00","updated_at":"2020-09-16T02:02:59.1803135+01:00","first_name":"Walton","last_name":"Howell","orders_count":-669497297,"state":"New Hampshire","total_spent":"bus","last_order_id":-443593710120194527,"note":"index","verified_email":true,"multipass_identifier":"compress","tax_exempt":true,"tags":"pixel","last_order_name":"connect","default_address":{"first_name":"Jennings","address1":"Adams Fort","phone":"Networked","city":"West Kayfurt","zip":"deposit","province":null,"country":"Lao People\u0027s Democratic Republic","last_name":"Howe","address2":null,"company":"Refined Plastic Chicken","latitude":0.81609845,"longitude":0.24733734,"name":"Refined Plastic Shirt","country_code":"BN","province_code":"Isle of Man"},"addresses":[{"first_name":"Emilio","address1":"TCP","phone":"Plastic","city":"Lake Eric","zip":"Synergistic","province":"SCSI","country":"Romania","last_name":"Jast","address2":"Cliff","company":"Senior","latitude":0.4901393,"longitude":0.7849145,"name":"Metal","country_code":"SI","province_code":"open-source"},{"first_name":"Domingo","address1":"customer loyalty","phone":"Small Plastic Tuna","city":"Morissetteland","zip":"Granite","province":"maximized","country":"Dominican Republic","last_name":"Nader","address2":"New York","company":"Berkshire","latitude":0.64874196,"longitude":0.6274609,"name":"6th generation","country_code":"KE","province_code":"Buckinghamshire"},{"first_name":"Miguel","address1":"intermediate","phone":"Avon","city":"Murazikview","zip":"morph","province":"Small Metal Chicken","country":"Nauru","last_name":"Quitzon","address2":"Automotive","company":"matrix","latitude":0.5843705,"longitude":0.6316814,"name":"Licensed","country_code":"CW","province_code":"Papua New Guinea"},{"first_name":"Jennings","address1":"Adams Fort","phone":"Networked","city":"West Kayfurt","zip":"deposit","province":null,"country":"Lao People\u0027s Democratic Republic","last_name":"Howe","address2":null,"company":"Refined Plastic Chicken","latitude":0.81609845,"longitude":0.24733734,"name":"Refined Plastic Shirt","country_code":"BN","province_code":"Isle of Man"}]},{"id":-3417109504508554134,"email":"Bertha_Mohr74@gmail.com","accepts_marketing":false,"created_at":"2020-09-15T20:52:59.134054+01:00","updated_at":"2020-09-16T01:01:06.1561632+01:00","first_name":"Nicola","last_name":"Bayer","orders_count":174255202,"state":"Rhode Island","total_spent":"interface","last_order_id":5132087489878657767,"note":"Rhode Island","verified_email":false,"multipass_identifier":"functionalities","tax_exempt":true,"tags":"driver","last_order_name":"modular","default_address":{"first_name":"Torrey","address1":"Bechtelar Skyway","phone":"invoice","city":"New Alvena","zip":"transmitter","province":null,"country":"Niger","last_name":"Schmeler","address2":null,"company":"multi-byte","latitude":0.35291028,"longitude":0.8415604,"name":"withdrawal","country_code":"CX","province_code":"Tokelau"},"addresses":[{"first_name":"Mauricio","address1":"Sri Lanka Rupee","phone":"cutting-edge","city":"North Stefanie","zip":"Wooden","province":"Island","country":"Gabon","last_name":"Quigley","address2":"Shore","company":"Clothing, Jewelery \u0026 Health","latitude":0.26150194,"longitude":0.30447736,"name":"Granite","country_code":"ID","province_code":"sensor"},{"first_name":"Marion","address1":"directional","phone":"e-tailers","city":"South Destany","zip":"Strategist","province":"IB","country":"Central African Republic","last_name":"Predovic","address2":"deposit","company":"facilitate","latitude":0.98393923,"longitude":0.88323647,"name":"B2C","country_code":"MS","province_code":"Fantastic Metal Cheese"},{"first_name":"Amalia","address1":"Ferry","phone":"monetize","city":"West Delmer","zip":"Netherlands Antillian Guilder","province":"Gorgeous Soft Bacon","country":"Namibia","last_name":"Jones","address2":"vortals","company":"Unbranded","latitude":0.31704956,"longitude":0.64807075,"name":"Communications","country_code":"SJ","province_code":"Cross-group"},{"first_name":"Torrey","address1":"Bechtelar Skyway","phone":"invoice","city":"New Alvena","zip":"transmitter","province":null,"country":"Niger","last_name":"Schmeler","address2":null,"company":"multi-byte","latitude":0.35291028,"longitude":0.8415604,"name":"withdrawal","country_code":"CX","province_code":"Tokelau"}]},{"id":-7106924800802664779,"email":"Merle_Smith41@hotmail.com","accepts_marketing":true,"created_at":"2020-09-16T07:53:06.9468818+01:00","updated_at":"2020-09-16T11:34:41.275922+01:00","first_name":"Deborah","last_name":"McKenzie","orders_count":-745380588,"state":"Pennsylvania","total_spent":"engineer","last_order_id":7429704761617103082,"note":"Baby, Industrial \u0026 Garden","verified_email":false,"multipass_identifier":"Technician","tax_exempt":true,"tags":"GB","last_order_name":"Checking Account","default_address":{"first_name":"Hershel","address1":"Aileen Harbor","phone":"Computers \u0026 Shoes","city":"New Charlieshire","zip":"Surinam Dollar","province":null,"country":"Russian Federation","last_name":"Reichel","address2":null,"company":"synthesize","latitude":0.20075199,"longitude":0.81114596,"name":"Berkshire","country_code":"DM","province_code":"Netherlands Antilles"},"addresses":[{"first_name":"Reanna","address1":"EXE","phone":"Berkshire","city":"New Davon","zip":"Health, Outdoors \u0026 Shoes","province":"Handmade Plastic Bike","country":"Switzerland","last_name":"Hagenes","address2":"Focused","company":"Ergonomic Metal Soap","latitude":0.03439409,"longitude":0.56035626,"name":"SMS","country_code":"HK","province_code":"Corner"},{"first_name":"Jimmy","address1":"generating","phone":"Fresh","city":"Port Cassandraborough","zip":"Dobra","province":"Security","country":"British Indian Ocean Territory (Chagos Archipelago)","last_name":"Hagenes","address2":"Investor","company":"Director","latitude":0.60966027,"longitude":0.14348973,"name":"Kyrgyz Republic","country_code":"BW","province_code":"Gorgeous"},{"first_name":"Maybelle","address1":"grey","phone":"Practical","city":"Lake Rowena","zip":"Soft","province":"Plastic","country":"Saint Kitts and Nevis","last_name":"McClure","address2":"Persistent","company":"compress","latitude":0.064481564,"longitude":0.109156184,"name":"hard drive","country_code":"MU","province_code":"Borders"},{"first_name":"Hershel","address1":"Aileen Harbor","phone":"Computers \u0026 Shoes","city":"New Charlieshire","zip":"Surinam Dollar","province":null,"country":"Russian Federation","last_name":"Reichel","address2":null,"company":"synthesize","latitude":0.20075199,"longitude":0.81114596,"name":"Berkshire","country_code":"DM","province_code":"Netherlands Antilles"}]},{"id":8949545254309485091,"email":"Martin.Thiel@yahoo.com","accepts_marketing":false,"created_at":"2020-09-15T13:38:08.6402094+01:00","updated_at":"2020-09-15T23:24:50.778218+01:00","first_name":"Shanna","last_name":"Bayer","orders_count":864426057,"state":"Vermont","total_spent":"Small","last_order_id":-2080819859544934330,"note":"Cape","verified_email":false,"multipass_identifier":"Rustic","tax_exempt":false,"tags":"bus","last_order_name":"circuit","default_address":{"first_name":"Jaren","address1":"Kenna Branch","phone":"scalable","city":"Kohlerhaven","zip":"navigating","province":"Rhode Island","country":"Iran","last_name":"Smitham","address2":null,"company":"Home Loan Account","latitude":0.032028932,"longitude":0.739671,"name":"Dynamic","country_code":"TF","province_code":"Division"},"addresses":[{"first_name":"Jayden","address1":"generate","phone":"Handmade Wooden Pants","city":"Maximilianville","zip":"Malaysian Ringgit","province":"Cotton","country":"Western Sahara","last_name":"Gorczany","address2":"Toys \u0026 Movies","company":"monetize","latitude":0.2338964,"longitude":0.2144667,"name":"Plaza","country_code":"KR","province_code":"Refined Concrete Chair"},{"first_name":"Thomas","address1":"Quality","phone":"Buckinghamshire","city":"Lake Emanuel","zip":"efficient","province":"Argentina","country":"Armenia","last_name":"Sanford","address2":"Books \u0026 Movies","company":"Unbranded Frozen Computer","latitude":0.072965436,"longitude":0.5123821,"name":"Applications","country_code":"DE","province_code":"granular"},{"first_name":"Rhoda","address1":"invoice","phone":"Turnpike","city":"Maybelleburgh","zip":"protocol","province":"Money Market Account","country":"Haiti","last_name":"Jacobs","address2":"open-source","company":"Investment Account","latitude":0.27449614,"longitude":0.36420134,"name":"SQL","country_code":"TG","province_code":"Canyon"},{"first_name":"Jaren","address1":"Kenna Branch","phone":"scalable","city":"Kohlerhaven","zip":"navigating","province":"Rhode Island","country":"Iran","last_name":"Smitham","address2":null,"company":"Home Loan Account","latitude":0.032028932,"longitude":0.739671,"name":"Dynamic","country_code":"TF","province_code":"Division"}]},{"id":6899350294010714119,"email":"Yolanda.Morissette@gmail.com","accepts_marketing":false,"created_at":"2020-09-15T21:36:54.1571671+01:00","updated_at":"2020-09-16T11:07:49.5573886+01:00","first_name":"Prudence","last_name":"Crona","orders_count":-377491751,"state":"Indiana","total_spent":"Sleek Soft Chips","last_order_id":-8413333610949793621,"note":"Fantastic Metal Sausages","verified_email":false,"multipass_identifier":"Wall","tax_exempt":false,"tags":"HTTP","last_order_name":"drive","default_address":{"first_name":"Carmen","address1":"Alycia Street","phone":"Rubber","city":"North Blaise","zip":"Graphic Interface","province":"Mississippi","country":"Ecuador","last_name":"Breitenberg","address2":"McClure Junctions","company":"capacitor","latitude":0.72716844,"longitude":0.90487486,"name":"Saint Lucia","country_code":"IS","province_code":"Regional"},"addresses":[{"first_name":"Talia","address1":"Saint Kitts and Nevis","phone":"Triple-buffered","city":"South Tomas","zip":"Enhanced","province":"composite","country":"Georgia","last_name":"Bergstrom","address2":"Shoes","company":"Gorgeous Steel Bike","latitude":0.9234881,"longitude":0.22459282,"name":"Automated","country_code":"ER","province_code":"mobile"},{"first_name":"Gabriella","address1":"Central","phone":"withdrawal","city":"Johathanview","zip":"SCSI","province":"morph","country":"Seychelles","last_name":"Stoltenberg","address2":"Decentralized","company":"Intelligent Fresh Sausages","latitude":0.020414451,"longitude":0.99502194,"name":"supply-chains","country_code":"SL","province_code":"New Jersey"},{"first_name":"Lafayette","address1":"Checking Account","phone":"Philippines","city":"East Theo","zip":"Dynamic","province":"Digitized","country":"Lithuania","last_name":"Metz","address2":"didactic","company":"Fall","latitude":0.5384821,"longitude":0.12336593,"name":"Industrial, Movies \u0026 Jewelery","country_code":"RS","province_code":"silver"},{"first_name":"Carmen","address1":"Alycia Street","phone":"Rubber","city":"North Blaise","zip":"Graphic Interface","province":"Mississippi","country":"Ecuador","last_name":"Breitenberg","address2":"McClure Junctions","company":"capacitor","latitude":0.72716844,"longitude":0.90487486,"name":"Saint Lucia","country_code":"IS","province_code":"Regional"}]},{"id":-3778032975407254800,"email":"Omar_Mosciski85@gmail.com","accepts_marketing":true,"created_at":"2020-09-15T19:31:52.5462541+01:00","updated_at":"2020-09-16T02:31:45.0645935+01:00","first_name":"Merle","last_name":"Kub","orders_count":-931625880,"state":"New Jersey","total_spent":"website","last_order_id":-6088520202553492436,"note":"web-readiness","verified_email":false,"multipass_identifier":"Borders","tax_exempt":true,"tags":"Gorgeous Granite Chicken","last_order_name":"SDD","default_address":{"first_name":"Dylan","address1":"Daugherty Park","phone":"Electronics, Computers \u0026 Industrial","city":"Lake Dorthyfort","zip":"Throughway","province":null,"country":"Comoros","last_name":"Hodkiewicz","address2":null,"company":"RSS","latitude":0.6209775,"longitude":0.53051823,"name":"executive","country_code":"NE","province_code":"Games, Electronics \u0026 Beauty"},"addresses":[{"first_name":"Maudie","address1":"architect","phone":"Intranet","city":"West Keyonhaven","zip":"Movies, Books \u0026 Sports","province":"Customizable","country":"Maldives","last_name":"Grady","address2":"override","company":"alarm","latitude":0.6429686,"longitude":0.970956,"name":"Bahamian Dollar","country_code":"US","province_code":"Burg"},{"first_name":"Thomas","address1":"Organized","phone":"navigate","city":"Litteltown","zip":"Interactions","province":"Baby","country":"Indonesia","last_name":"Jacobi","address2":"Planner","company":"Locks","latitude":0.8698107,"longitude":0.731467,"name":"Money Market Account","country_code":"SG","province_code":"Small Frozen Chips"},{"first_name":"Lora","address1":"withdrawal","phone":"collaboration","city":"New Rodrigochester","zip":"XSS","province":"Ergonomic Steel Fish","country":"Burkina Faso","last_name":"Tremblay","address2":"multi-byte","company":"vortals","latitude":0.14484808,"longitude":0.87789977,"name":"Clothing","country_code":"SB","province_code":"secured line"},{"first_name":"Dylan","address1":"Daugherty Park","phone":"Electronics, Computers \u0026 Industrial","city":"Lake Dorthyfort","zip":"Throughway","province":null,"country":"Comoros","last_name":"Hodkiewicz","address2":null,"company":"RSS","latitude":0.6209775,"longitude":0.53051823,"name":"executive","country_code":"NE","province_code":"Games, Electronics \u0026 Beauty"}]},{"id":-4689669204933749946,"email":"Charles72@yahoo.com","accepts_marketing":true,"created_at":"2020-09-15T23:25:22.092293+01:00","updated_at":"2020-09-15T18:57:16.7552867+01:00","first_name":"Kenton","last_name":"Koch","orders_count":-438360010,"state":"Nevada","total_spent":"calculating","last_order_id":-2896626752948651046,"note":"e-business","verified_email":false,"multipass_identifier":"AI","tax_exempt":true,"tags":"payment","last_order_name":"Puerto Rico","default_address":{"first_name":"Elisa","address1":"Beulah Spring","phone":"Isle of Man","city":"Jazminhaven","zip":"Incredible Plastic Ball","province":null,"country":"Rwanda","last_name":"Quitzon","address2":null,"company":"Handcrafted Plastic Fish","latitude":0.2760999,"longitude":0.46997577,"name":"Legacy","country_code":"IL","province_code":"human-resource"},"addresses":[{"first_name":"Savanna","address1":"Soft","phone":"Factors","city":"East Tyrique","zip":"quantify","province":"quantifying","country":"Luxembourg","last_name":"Kertzmann","address2":"Assurance","company":"Optimization","latitude":0.4122294,"longitude":0.52551705,"name":"Business-focused","country_code":"KN","province_code":"Proactive"},{"first_name":"Evie","address1":"demand-driven","phone":"Washington","city":"Luciotown","zip":"schemas","province":"Intelligent","country":"Lesotho","last_name":"Jast","address2":"payment","company":"Horizontal","latitude":0.77900875,"longitude":0.67005265,"name":"interface","country_code":"CI","province_code":"Fantastic"},{"first_name":"Donnell","address1":"Unbranded","phone":"Baby, Sports \u0026 Shoes","city":"Port Antonio","zip":"Programmable","province":"Handcrafted Granite Bike","country":"Armenia","last_name":"Gaylord","address2":"system-worthy","company":"Pass","latitude":0.85766137,"longitude":0.3249882,"name":"initiatives","country_code":"KM","province_code":"Money Market Account"},{"first_name":"Elisa","address1":"Beulah Spring","phone":"Isle of Man","city":"Jazminhaven","zip":"Incredible Plastic Ball","province":null,"country":"Rwanda","last_name":"Quitzon","address2":null,"company":"Handcrafted Plastic Fish","latitude":0.2760999,"longitude":0.46997577,"name":"Legacy","country_code":"IL","province_code":"human-resource"}]},{"id":-4041878022023765415,"email":"Roberto.Gaylord@yahoo.com","accepts_marketing":false,"created_at":"2020-09-15T18:14:01.6028166+01:00","updated_at":"2020-09-16T10:46:31.4446926+01:00","first_name":"Eliezer","last_name":"Cartwright","orders_count":1846689202,"state":"Hawaii","total_spent":"digital","last_order_id":2816403395251511877,"note":"index","verified_email":true,"multipass_identifier":"hybrid","tax_exempt":true,"tags":"Customer","last_order_name":"Egyptian Pound","default_address":{"first_name":"Caroline","address1":"Thompson Park","phone":"synthesizing","city":"East Willow","zip":"Mississippi","province":null,"country":"Kyrgyz Republic","last_name":"Koss","address2":null,"company":"Cambridgeshire","latitude":0.41614023,"longitude":0.32436183,"name":"navigate","country_code":"JO","province_code":"Groves"},"addresses":[{"first_name":"Gerhard","address1":"collaborative","phone":"e-enable","city":"Ernserton","zip":"HTTP","province":"override","country":"Algeria","last_name":"Cronin","address2":"programming","company":"Coordinator","latitude":0.70632035,"longitude":0.3543656,"name":"explicit","country_code":"NI","province_code":"Gorgeous Plastic Computer"},{"first_name":"Carmel","address1":"Rubber","phone":"Crescent","city":"East Emanuel","zip":"e-business","province":"hard drive","country":"Liberia","last_name":"Pagac","address2":"Macedonia","company":"Course","latitude":0.07746598,"longitude":0.4352318,"name":"transmitter","country_code":"PR","province_code":"Synchronised"},{"first_name":"Kelsie","address1":"Saint Helena Pound","phone":"deposit","city":"North Karolannshire","zip":"Intranet","province":"customized","country":"Uganda","last_name":"Boyle","address2":"Movies","company":"Central","latitude":0.23812152,"longitude":0.8761952,"name":"Awesome","country_code":"MR","province_code":"Islands"},{"first_name":"Caroline","address1":"Thompson Park","phone":"synthesizing","city":"East Willow","zip":"Mississippi","province":null,"country":"Kyrgyz Republic","last_name":"Koss","address2":null,"company":"Cambridgeshire","latitude":0.41614023,"longitude":0.32436183,"name":"navigate","country_code":"JO","province_code":"Groves"}]},{"id":-7565647674963994176,"email":"Sadie.Reichel@yahoo.com","accepts_marketing":true,"created_at":"2020-09-16T07:26:48.5405005+01:00","updated_at":"2020-09-16T00:40:50.9349815+01:00","first_name":"Rosalia","last_name":"Cormier","orders_count":-2072718639,"state":"New Hampshire","total_spent":"Balboa","last_order_id":-2138284864134798300,"note":"IB","verified_email":false,"multipass_identifier":"Washington","tax_exempt":false,"tags":"incentivize","last_order_name":"5th generation","default_address":{"first_name":"Jaren","address1":"Bernhard Courts","phone":"Haven","city":"Arvidborough","zip":"Music, Shoes \u0026 Games","province":"Wisconsin","country":"Ecuador","last_name":"Roberts","address2":null,"company":"green","latitude":0.39063382,"longitude":0.99522275,"name":"Vanuatu","country_code":"GM","province_code":"migration"},"addresses":[{"first_name":"Maudie","address1":"Way","phone":"invoice","city":"North Nikitaton","zip":"Rustic Steel Shirt","province":"Rustic Granite Sausages","country":"Finland","last_name":"Johns","address2":"Credit Card Account","company":"backing up","latitude":0.55163443,"longitude":0.759564,"name":"lavender","country_code":"FM","province_code":"Central"},{"first_name":"Kaitlin","address1":"Jewelery, Music \u0026 Health","phone":"Brand","city":"Lindgrenchester","zip":"Response","province":"experiences","country":"Falkland Islands (Malvinas)","last_name":"Wolf","address2":"Wyoming","company":"CSS","latitude":0.35208708,"longitude":0.51240605,"name":"Gorgeous","country_code":"UG","province_code":"Officer"},{"first_name":"Dewitt","address1":"Branding","phone":"deposit","city":"South Alecport","zip":"Cotton","province":"customer loyalty","country":"Japan","last_name":"Graham","address2":"Oval","company":"Investment Account","latitude":0.19283903,"longitude":0.021121597,"name":"reboot","country_code":"AR","province_code":"B2B"},{"first_name":"Jaren","address1":"Bernhard Courts","phone":"Haven","city":"Arvidborough","zip":"Music, Shoes \u0026 Games","province":"Wisconsin","country":"Ecuador","last_name":"Roberts","address2":null,"company":"green","latitude":0.39063382,"longitude":0.99522275,"name":"Vanuatu","country_code":"GM","province_code":"migration"}]},{"id":-4973236664073249568,"email":"Josephine67@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T13:55:03.9343943+01:00","updated_at":"2020-09-15T19:12:07.0146184+01:00","first_name":"Maximillian","last_name":"Conn","orders_count":102608215,"state":"Georgia","total_spent":"Corporate","last_order_id":-9106580734876984801,"note":"France","verified_email":false,"multipass_identifier":"port","tax_exempt":true,"tags":"Sleek Rubber Computer","last_order_name":"synthesize","default_address":{"first_name":"Daphney","address1":"Greta Mountains","phone":"Connecticut","city":"Port Patiencechester","zip":"reboot","province":null,"country":"Belgium","last_name":"Hessel","address2":null,"company":"application","latitude":0.98563,"longitude":0.59388125,"name":"Personal Loan Account","country_code":"SS","province_code":"index"},"addresses":[{"first_name":"Tomasa","address1":"Investment Account","phone":"scale","city":"Pourosburgh","zip":"Isle","province":"Money Market Account","country":"Afghanistan","last_name":"Hills","address2":"Fantastic","company":"Refined Cotton Chips","latitude":0.57599384,"longitude":0.88484013,"name":"Rubber","country_code":"BA","province_code":"Soft"},{"first_name":"Bart","address1":"Gorgeous Plastic Ball","phone":"Greenland","city":"Emardmouth","zip":"didactic","province":"Outdoors \u0026 Jewelery","country":"Morocco","last_name":"Block","address2":"Practical Plastic Shoes","company":"Courts","latitude":0.2581672,"longitude":0.90198493,"name":"Estate","country_code":"RU","province_code":"Fantastic"},{"first_name":"Kyla","address1":"Incredible Concrete Tuna","phone":"Avon","city":"New Hoseaville","zip":"withdrawal","province":"systems","country":"Guyana","last_name":"Tillman","address2":"Quality","company":"Internal","latitude":0.23428847,"longitude":0.66261953,"name":"intuitive","country_code":"BG","province_code":"hacking"},{"first_name":"Daphney","address1":"Greta Mountains","phone":"Connecticut","city":"Port Patiencechester","zip":"reboot","province":null,"country":"Belgium","last_name":"Hessel","address2":null,"company":"application","latitude":0.98563,"longitude":0.59388125,"name":"Personal Loan Account","country_code":"SS","province_code":"index"}]},{"id":432899825663737201,"email":"Clinton.Wunsch96@yahoo.com","accepts_marketing":true,"created_at":"2020-09-16T10:43:47.0731455+01:00","updated_at":"2020-09-16T11:23:57.5893554+01:00","first_name":"Erica","last_name":"Abshire","orders_count":2116473710,"state":"Texas","total_spent":"Iowa","last_order_id":9056210466507615207,"note":"Solutions","verified_email":true,"multipass_identifier":"Fantastic Concrete Towels","tax_exempt":false,"tags":"Glen","last_order_name":"Money Market Account","default_address":{"first_name":"Sarai","address1":"Mable Ways","phone":"1080p","city":"Rennerton","zip":"leading edge","province":null,"country":"Rwanda","last_name":"Koelpin","address2":null,"company":"Intelligent","latitude":0.23414499,"longitude":0.21025237,"name":"Response","country_code":"BL","province_code":"Licensed Rubber Hat"},"addresses":[{"first_name":"Milton","address1":"Intelligent","phone":"bypass","city":"Tremblaymouth","zip":"Illinois","province":"Direct","country":"Greece","last_name":"Botsford","address2":"Associate","company":"parse","latitude":0.24757874,"longitude":0.90703064,"name":"withdrawal","country_code":"HT","province_code":"Division"},{"first_name":"Johann","address1":"Views","phone":"Money Market Account","city":"Pfefferburgh","zip":"deposit","province":"Frozen","country":"Botswana","last_name":"Anderson","address2":"Forint","company":"sky blue","latitude":0.15028691,"longitude":0.83851177,"name":"copy","country_code":"MS","province_code":"online"},{"first_name":"Santiago","address1":"models","phone":"synthesize","city":"New Lambertmouth","zip":"Greece","province":"Riel","country":"Saint Barthelemy","last_name":"Cruickshank","address2":"Intuitive","company":"Borders","latitude":0.65517205,"longitude":0.79988337,"name":"Fundamental","country_code":"NI","province_code":"input"},{"first_name":"Sarai","address1":"Mable Ways","phone":"1080p","city":"Rennerton","zip":"leading edge","province":null,"country":"Rwanda","last_name":"Koelpin","address2":null,"company":"Intelligent","latitude":0.23414499,"longitude":0.21025237,"name":"Response","country_code":"BL","province_code":"Licensed Rubber Hat"}]},{"id":-3226152741588649519,"email":"Kerry61@yahoo.com","accepts_marketing":true,"created_at":"2020-09-16T06:26:08.8370379+01:00","updated_at":"2020-09-15T16:21:18.1187766+01:00","first_name":"Kyler","last_name":"Skiles","orders_count":-1899073476,"state":"Delaware","total_spent":"Kids \u0026 Grocery","last_order_id":-1625481342305023164,"note":"grow","verified_email":true,"multipass_identifier":"Open-architected","tax_exempt":false,"tags":"parsing","last_order_name":"feed","default_address":{"first_name":"Gloria","address1":"Hamill Mills","phone":"deposit","city":"Hesseltown","zip":"holistic","province":null,"country":"Lao People\u0027s Democratic Republic","last_name":"Jast","address2":null,"company":"Human","latitude":0.1319251,"longitude":0.5778661,"name":"primary","country_code":"AQ","province_code":"Personal Loan Account"},"addresses":[{"first_name":"Kelly","address1":"multi-byte","phone":"Gibraltar","city":"Swiftside","zip":"modular","province":"Wooden","country":"French Southern Territories","last_name":"Olson","address2":"Kids \u0026 Tools","company":"Sao Tome and Principe","latitude":0.80056536,"longitude":0.16418037,"name":"Shoes \u0026 Books","country_code":"GP","province_code":"Product"},{"first_name":"Noemi","address1":"parsing","phone":"National","city":"Robertsborough","zip":"Product","province":"Intelligent Concrete Chair","country":"Mayotte","last_name":"Cremin","address2":"Organized","company":"Kids","latitude":0.6789156,"longitude":0.400179,"name":"1080p","country_code":"NI","province_code":"withdrawal"},{"first_name":"Karli","address1":"Group","phone":"Alabama","city":"Runolfsdottirmouth","zip":"Unbranded Soft Bike","province":"Checking Account","country":"Palestinian Territory","last_name":"Wintheiser","address2":"Personal Loan Account","company":"web services","latitude":0.63000166,"longitude":0.4250542,"name":"Beauty \u0026 Clothing","country_code":"BI","province_code":"Money Market Account"},{"first_name":"Gloria","address1":"Hamill Mills","phone":"deposit","city":"Hesseltown","zip":"holistic","province":null,"country":"Lao People\u0027s Democratic Republic","last_name":"Jast","address2":null,"company":"Human","latitude":0.1319251,"longitude":0.5778661,"name":"primary","country_code":"AQ","province_code":"Personal Loan Account"}]},{"id":3655308811762435174,"email":"Vincent.Farrell84@gmail.com","accepts_marketing":false,"created_at":"2020-09-15T13:13:02.7152792+01:00","updated_at":"2020-09-15T12:17:49.6331617+01:00","first_name":"Jerel","last_name":"O\u0027Connell","orders_count":565119180,"state":"Idaho","total_spent":"strategic","last_order_id":5121683026088533035,"note":"Saint Martin","verified_email":true,"multipass_identifier":"Small Concrete Ball","tax_exempt":false,"tags":"Port","last_order_name":"navigating","default_address":{"first_name":"Herminio","address1":"Brook Hills","phone":"navigate","city":"Port Lunaburgh","zip":"deliver","province":null,"country":"Croatia","last_name":"Beatty","address2":null,"company":"Gourde","latitude":0.74068326,"longitude":0.7486318,"name":"Lakes","country_code":"FR","province_code":"Refined"},"addresses":[{"first_name":"Amir","address1":"FTP","phone":"transition","city":"West Lafayettemouth","zip":"hack","province":"Administrator","country":"South Georgia and the South Sandwich Islands","last_name":"Gorczany","address2":"Alaska","company":"Supervisor","latitude":0.21650855,"longitude":0.7255431,"name":"scalable","country_code":"LY","province_code":"firmware"},{"first_name":"Chaz","address1":"innovate","phone":"program","city":"North Carlee","zip":"Creative","province":"Licensed Metal Salad","country":"Malawi","last_name":"Hessel","address2":"reintermediate","company":"Guyana","latitude":0.24180923,"longitude":0.93221164,"name":"SSL","country_code":"FK","province_code":"User-friendly"},{"first_name":"Camille","address1":"niches","phone":"payment","city":"Port Berniece","zip":"Jewelery, Shoes \u0026 Tools","province":"back-end","country":"Andorra","last_name":"Waters","address2":"Tunnel","company":"deposit","latitude":0.5461558,"longitude":0.9443179,"name":"parsing","country_code":"LB","province_code":"Refined Wooden Hat"},{"first_name":"Herminio","address1":"Brook Hills","phone":"navigate","city":"Port Lunaburgh","zip":"deliver","province":null,"country":"Croatia","last_name":"Beatty","address2":null,"company":"Gourde","latitude":0.74068326,"longitude":0.7486318,"name":"Lakes","country_code":"FR","province_code":"Refined"}]},{"id":7305686240857555611,"email":"Duane.Will@hotmail.com","accepts_marketing":false,"created_at":"2020-09-15T14:33:03.3615186+01:00","updated_at":"2020-09-15T13:11:09.5656945+01:00","first_name":"Gregoria","last_name":"Glover","orders_count":469722879,"state":"Nebraska","total_spent":"cohesive","last_order_id":-3665587939816874673,"note":"teal","verified_email":false,"multipass_identifier":"Graphical User Interface","tax_exempt":false,"tags":"Checking Account","last_order_name":"Administrator","default_address":{"first_name":"Alexis","address1":"Schuster Lake","phone":"Denar","city":"Bradtkeland","zip":"e-tailers","province":"Maryland","country":"Congo","last_name":"Green","address2":"Kyle Harbors","company":"Intranet","latitude":0.2534823,"longitude":0.42616767,"name":"invoice","country_code":"LA","province_code":"Savings Account"},"addresses":[{"first_name":"Adaline","address1":"mesh","phone":"Legacy","city":"Schimmelfort","zip":"Investment Account","province":"withdrawal","country":"Guernsey","last_name":"Schoen","address2":"Sleek Wooden Bacon","company":"Rustic","latitude":0.05592875,"longitude":0.42815372,"name":"bandwidth","country_code":"MY","province_code":"Branding"},{"first_name":"Golden","address1":"protocol","phone":"Cambridgeshire","city":"Rosalynfurt","zip":"Profound","province":"unleash","country":"Reunion","last_name":"Dickinson","address2":"transmitter","company":"New Hampshire","latitude":0.9235264,"longitude":0.35687974,"name":"Concrete","country_code":"PL","province_code":"bus"},{"first_name":"Cydney","address1":"Plastic","phone":"Ergonomic Cotton Ball","city":"Runtetown","zip":"Future","province":"Agent","country":"Palau","last_name":"Ritchie","address2":"leading edge","company":"Money Market Account","latitude":0.5705042,"longitude":0.85383874,"name":"Unbranded Granite Cheese","country_code":"HU","province_code":"Comoro Franc"},{"first_name":"Alexis","address1":"Schuster Lake","phone":"Denar","city":"Bradtkeland","zip":"e-tailers","province":"Maryland","country":"Congo","last_name":"Green","address2":"Kyle Harbors","company":"Intranet","latitude":0.2534823,"longitude":0.42616767,"name":"invoice","country_code":"LA","province_code":"Savings Account"}]},{"id":-2450321883376302498,"email":"Alexis_Thiel66@hotmail.com","accepts_marketing":true,"created_at":"2020-09-15T20:39:51.9607651+01:00","updated_at":"2020-09-16T11:19:23.5700914+01:00","first_name":"Erik","last_name":"Tromp","orders_count":-263155800,"state":"Hawaii","total_spent":"Station","last_order_id":-6693628180844590522,"note":"Guinea-Bissau","verified_email":false,"multipass_identifier":"Savings Account","tax_exempt":false,"tags":"application","last_order_name":"Berkshire","default_address":{"first_name":"Lane","address1":"Joey Vista","phone":"invoice","city":"West Ryleighburgh","zip":"back-end","province":null,"country":"Turkey","last_name":"Rippin","address2":null,"company":"Coves","latitude":0.22509784,"longitude":0.16279897,"name":"Berkshire","country_code":"NA","province_code":"analyzer"},"addresses":[{"first_name":"Drake","address1":"Lights","phone":"cyan","city":"Kuvalisfort","zip":"Practical Concrete Sausages","province":"Engineer","country":"Myanmar","last_name":"West","address2":"robust","company":"Chief","latitude":0.33437592,"longitude":0.18548732,"name":"Home Loan Account","country_code":"ME","province_code":"Intelligent Granite Table"},{"first_name":"Quentin","address1":"integrated","phone":"Cambridgeshire","city":"North Lilian","zip":"compress","province":"TCP","country":"Gibraltar","last_name":"Gleason","address2":"Accounts","company":"Money Market Account","latitude":0.9771962,"longitude":0.59250027,"name":"tertiary","country_code":"DK","province_code":"Buckinghamshire"},{"first_name":"Jammie","address1":"matrix","phone":"deploy","city":"Grahamborough","zip":"RAM","province":"Utah","country":"Iceland","last_name":"Rau","address2":"convergence","company":"exploit","latitude":0.6584244,"longitude":0.3303229,"name":"capacity","country_code":"IL","province_code":"Open-architected"},{"first_name":"Lane","address1":"Joey Vista","phone":"invoice","city":"West Ryleighburgh","zip":"back-end","province":null,"country":"Turkey","last_name":"Rippin","address2":null,"company":"Coves","latitude":0.22509784,"longitude":0.16279897,"name":"Berkshire","country_code":"NA","province_code":"analyzer"}]}]} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We store other test payloads in this Strings.resx
file. Based on some other entries, the data name should be SomeDescriptivePayloadSize
e.g. BigPayloadWithNulls101KB
.
The usage would be string json = SR.BigPayloadWithNulls101KB;
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A couple test comments, otherwise LGTM.
[InlineData("Issue42070_0004.json")] | ||
[InlineData("Issue42070_0228.json")] | ||
[InlineData("CustomerSearchApi108KB")] | ||
[InlineData("CustomerSearchApi107KB")] | ||
public static async Task ContinuationAtNullToken(string resourceName) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: this test can be written as
// From https://github.com/dotnet/runtime/issues/42070
[Theory]
[MemberData(nameof(ContinuationAtNullTokenTestData))]
public static async Task ContinuationAtNullToken(string payload)
{
using (Stream stream = new MemoryStream(Encoding.UTF8.GetBytes(payload)))
{
CustomerCollectionResponse response = await JsonSerializer.DeserializeAsync<CustomerCollectionResponse>(stream, new JsonSerializerOptions { IgnoreNullValues = true });
Assert.Equal(50, response.Customers.Count);
}
}
private static IEnumerable<object[]> ContinuationAtNullTokenTestData()
{
yield return new object[] { SR.CustomerSearchApi108KB };
yield return new object[] { SR.CustomerSearchApi107KB };
}
|
||
namespace System.Text.Json.Serialization.Tests | ||
{ | ||
public static class ContinuationTests |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The first four tests in this file are very similar, the only difference being the inner type passed to outer, and also an Assert.Null
test if the inner type is a reference type. To avoid the duplication: can we consolidate them into one generic test helper, and run the test like this?
[Theory]
[MemberData(nameof(TestData))]
public static async Task ContinuationShouldWorkAtAnyPosition_ParameterlessCtor(int paddingLength, bool ignoreNullValues)
{
await RunTest<TestClass<NestedClass>, NestedClass>(paddingLength, ignoreNullValues);
await RunTest<TestClass<NestedValueType>, NestedValueType>(paddingLength, ignoreNullValues);
await RunTest<TestValueType<NestedClass>, NestedClass>(paddingLength, ignoreNullValues);
await RunTest<TestValueType<NestedValueType>, NestedValueType>(paddingLength, ignoreNullValues);
}
private static async Task RunTest<TInner, TInnermost>(int paddingLength, bool ignoreNullValues)
where TInner : ITestInterface<TInnermost>, new()
where TInnermost : INestedInterface, new()
{
var stream = new MemoryStream();
{
var obj = new Outer<TInner>
{
S = new string('x', paddingLength),
C = new()
{
A = "Hello",
B = null,
C = 42,
D = null,
E = 3.14e+17f,
F = null,
G = true,
H = null,
I = new int[] { 42, 17 },
J = new()
{
A = null,
B = 7,
}
}
};
await JsonSerializer.SerializeAsync(stream, obj, new JsonSerializerOptions { Converters = { new OuterConverter<TestClass<NestedClass>>() } });
}
stream.Position = 0;
{
var readOptions = new JsonSerializerOptions
{
DefaultBufferSize = 128,
IgnoreNullValues = ignoreNullValues,
};
Outer<TestClass<NestedClass>> obj = await JsonSerializer.DeserializeAsync<Outer<TestClass<NestedClass>>>(stream, readOptions);
Assert.Equal(new string('x', paddingLength), obj.S);
Assert.Equal("Hello", obj.C.A);
Assert.Null(obj.C.B);
Assert.Equal(42, obj.C.C);
Assert.Null(obj.C.D);
Assert.Equal(3.14e17f, obj.C.E);
Assert.Null(obj.C.F);
Assert.True(obj.C.G);
Assert.Null(obj.C.H);
Assert.Collection(obj.C.I, v => Assert.Equal(42, v), v => Assert.Equal(17, v));
bool innerIsRefType = typeof(TInner).IsValueType == false;
if (innerIsRefType)
{
Assert.NotNull(obj.C.J);
}
Assert.Null(obj.C.J.A);
Assert.Equal(7, obj.C.J.B);
}
}
private interface ITestInterface<TNested>
{
public string A { get; set; }
public string B { get; set; }
public int C { get; set; }
public int? D { get; set; }
public float E { get; set; }
public float? F { get; set; }
public bool G { get; set; }
public bool? H { get; set; }
public int[] I { get; set; }
public TNested J { get; set; }
}
private class TestClass<TNested> : ITestInterface<TNested>
{
public string A { get; set; }
public string B { get; set; }
public int C { get; set; }
public int? D { get; set; }
public float E { get; set; }
public float? F { get; set; }
public bool G { get; set; }
public bool? H { get; set; }
public int[] I { get; set; }
public TNested J { get; set; }
}
private class TestValueType<TNested> : ITestInterface<TNested>
{
public string A { get; set; }
public string B { get; set; }
public int C { get; set; }
public int? D { get; set; }
public float E { get; set; }
public float? F { get; set; }
public bool G { get; set; }
public bool? H { get; set; }
public int[] I { get; set; }
public TNested J { get; set; }
}
private interface INestedInterface
{
public string A { get; set; }
public int B { get; set; }
}
private class NestedClass : INestedInterface
{
public string A { get; set; }
public int B { get; set; }
}
private struct NestedValueType : INestedInterface
{
public string A { get; set; }
public int B { get; set; }
}
I didn't look further, but there might be a way to abstract further and reduce duplicate LOC for the parameterized ctor test; up to you.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The first four tests in this file are very similar
I already completely refactored this for the same reason. Follow up PR is coming soon.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Above feedback on tests can be addressed in follow up. Merging now to get this PR ready for ship-room consideration for .NET 5.
Thanks @devsko
* Repro dotnet#42070 * formatting * namespace * Fix * never forget the header * More tests - Test continuation at every position inside the tested object - Many member with primitive and nullable types - One more level of nested object - All combinations of class/struct for tested and nested object - tested and nested object with parametrized ctor for some properties * Addressed feedback * Test with original repro data from dotnet#42070 * custom converter to ensure the padding is written in front of the tested object * rename * test data moved to Strings.resx
@devsko - can you include a test for when partial buffer ends on a valid prefix for e.g. Initial buffer: Next buffer: |
* Repro #42070 * formatting * namespace * Fix * never forget the header * More tests - Test continuation at every position inside the tested object - Many member with primitive and nullable types - One more level of nested object - All combinations of class/struct for tested and nested object - tested and nested object with parametrized ctor for some properties * Addressed feedback * Test with original repro data from #42070 * custom converter to ensure the padding is written in front of the tested object * rename * test data moved to Strings.resx Co-authored-by: devsko <devsko@users.noreply.github.com>
Fixes #42070
When deserialization continues with a new chunk of data in the middle of a null token, a
JsonException
is thrown.This PR attempts to fix this issue.
I verified that the change fixes the original repro.
I also verified that the two test cases (but with payload just beneath 2GB) mentioned by @am11 in this comment work as expected with the changes in this PR.
The risk of regressions is low. Only continuation situations at null tokens are affected that throw or result in unexpected null values without the change.