[{"data":1,"prerenderedAt":16061},["ShallowReactive",2],{"navigation":3,"/testing/performance-testing":1016,"/testing/performance-testing-surround":16056},[4,54,89,123,165,211,253,331,389,439,462,488,514,540,578,624,650,672,702,736,774,800,850,856,862,868,874,928],{"title":5,"path":6,"stem":7,"children":8},"Introduction and Foundations","/introduction-and-foundations","01.introduction-and-foundations/01.index",[9,10,14,18,22,26,30,34,38,42,46,50],{"title":5,"path":6,"stem":7},{"title":11,"path":12,"stem":13},"What is Django","/introduction-and-foundations/what-is-django","01.introduction-and-foundations/02.what-is-django",{"title":15,"path":16,"stem":17},"Key Concepts and Philosophy","/introduction-and-foundations/key-concepts-and-philosophy","01.introduction-and-foundations/03.key-concepts-and-philosophy",{"title":19,"path":20,"stem":21},"MVC vs MVT: Understanding Django's Architecture","/introduction-and-foundations/mvc-vs-mvt","01.introduction-and-foundations/04.mvc-vs-mvt",{"title":23,"path":24,"stem":25},"Project Structure Overview","/introduction-and-foundations/project-structure-overview","01.introduction-and-foundations/05.project-structure-overview",{"title":27,"path":28,"stem":29},"Installing Django","/introduction-and-foundations/installing-django","01.introduction-and-foundations/06.installing-django",{"title":31,"path":32,"stem":33},"Creating Your First Django Project","/introduction-and-foundations/creating-first-project","01.introduction-and-foundations/07.creating-first-project",{"title":35,"path":36,"stem":37},"Creating Your First Django App","/introduction-and-foundations/creating-first-app","01.introduction-and-foundations/08.creating-first-app",{"title":39,"path":40,"stem":41},"Your First Django \"Hello World\"","/introduction-and-foundations/hello-world","01.introduction-and-foundations/09.hello-world",{"title":43,"path":44,"stem":45},"Django Quick Start Guide","/introduction-and-foundations/quick-start-guide","01.introduction-and-foundations/10.quick-start-guide",{"title":47,"path":48,"stem":49},"How Django Handles Requests","/introduction-and-foundations/how-django-handles-requests","01.introduction-and-foundations/11.how-django-handles-requests",{"title":51,"path":52,"stem":53},"Django Settings","/introduction-and-foundations/django-settings","01.introduction-and-foundations/12.django-settings",{"title":55,"path":56,"stem":57,"children":58},"The Development Environment","/development-environment","02.development-environment/1.index",[59,61,65,69,73,77,81,85],{"title":60,"path":56,"stem":57},"Development Environment",{"title":62,"path":63,"stem":64},"Recommended Tooling for Django Development","/development-environment/recommended-tooling","02.development-environment/2.recommended-tooling",{"title":66,"path":67,"stem":68},"Virtual Environments","/development-environment/virtual-environments","02.development-environment/3.virtual-environments",{"title":70,"path":71,"stem":72},"Django Admin and Management Commands","/development-environment/admin-and-management-commands","02.development-environment/4.admin-and-management-commands",{"title":74,"path":75,"stem":76},"Django Project Settings","/development-environment/project-settings","02.development-environment/5.project-settings",{"title":78,"path":79,"stem":80},"Managing Django Environments: Local, Staging, and Production","/development-environment/environments-local-staging-production","02.development-environment/6.environments-local-staging-production",{"title":82,"path":83,"stem":84},"Running Django Development Server","/development-environment/running-development-server","02.development-environment/7.running-development-server",{"title":86,"path":87,"stem":88},"Working with Django Shell","/development-environment/working-with-shell","02.development-environment/8.working-with-shell",{"title":90,"path":91,"stem":92,"children":93},"Templates and Presentation Layer","/templates-and-presentation","03.templates-and-presentation/1.index",[94,95,99,103,107,111,115,119],{"title":90,"path":91,"stem":92},{"title":96,"path":97,"stem":98},"Introduction to Django Templates","/templates-and-presentation/introduction-to-templates","03.templates-and-presentation/2.introduction-to-templates",{"title":100,"path":101,"stem":102},"The Django Template Language","/templates-and-presentation/django-template-language","03.templates-and-presentation/3.django-template-language",{"title":104,"path":105,"stem":106},"Template Inheritance","/templates-and-presentation/template-inheritance","03.templates-and-presentation/4.template-inheritance",{"title":108,"path":109,"stem":110},"Built-in Template Tags and Filters","/templates-and-presentation/built-in-template-tags-and-filters","03.templates-and-presentation/5.built-in-template-tags-and-filters",{"title":112,"path":113,"stem":114},"Including Static Files","/templates-and-presentation/including-static-files","03.templates-and-presentation/6.including-static-files",{"title":116,"path":117,"stem":118},"Working with Media Files","/templates-and-presentation/working-with-media-files","03.templates-and-presentation/7.working-with-media-files",{"title":120,"path":121,"stem":122},"Using Alternative Template Engines","/templates-and-presentation/using-alternative-template-engines","03.templates-and-presentation/8.using-alternative-template-engines",{"title":124,"path":125,"stem":126,"children":127},"URLs and Views","/urls-and-views","04.urls-and-views/01.index",[128,129,133,137,141,145,149,153,157,161],{"title":124,"path":125,"stem":126},{"title":130,"path":131,"stem":132},"The URL Dispatcher","/urls-and-views/the-url-dispatcher","04.urls-and-views/02.the-url-dispatcher",{"title":134,"path":135,"stem":136},"Writing Function-Based Views","/urls-and-views/writing-function-based-views","04.urls-and-views/03.writing-function-based-views",{"title":138,"path":139,"stem":140},"View Decorators","/urls-and-views/view-decorators","04.urls-and-views/04.view-decorators",{"title":142,"path":143,"stem":144},"Rendering Responses","/urls-and-views/rendering-responses","04.urls-and-views/05.rendering-responses",{"title":146,"path":147,"stem":148},"Redirects","/urls-and-views/redirects","04.urls-and-views/06.redirects",{"title":150,"path":151,"stem":152},"Handling HTTP Methods","/urls-and-views/handling-http-methods","04.urls-and-views/07.handling-http-methods",{"title":154,"path":155,"stem":156},"Conditional View Processing","/urls-and-views/conditional-view-processing","04.urls-and-views/08.conditional-view-processing",{"title":158,"path":159,"stem":160},"File Uploads","/urls-and-views/file-uploads","04.urls-and-views/09.file-uploads",{"title":162,"path":163,"stem":164},"Using Django Shortcut Functions","/urls-and-views/using-django-shortcut-functions","04.urls-and-views/10.using-django-shortcut-functions",{"title":166,"path":167,"stem":168,"children":169},"Class Based Views","/class-based-views","05.class-based-views/01.index",[170,171,175,179,183,187,191,195,199,203,207],{"title":166,"path":167,"stem":168},{"title":172,"path":173,"stem":174},"Introduction to Class-Based Views","/class-based-views/introduction-to-class-based-views","05.class-based-views/02.introduction-to-class-based-views",{"title":176,"path":177,"stem":178},"Common Base Classes","/class-based-views/common-base-classes","05.class-based-views/03.common-base-classes",{"title":180,"path":181,"stem":182},"Built-in Generic Views","/class-based-views/built-in-generic-views","05.class-based-views/04.built-in-generic-views",{"title":184,"path":185,"stem":186},"Views for CRUD Operations","/class-based-views/views-for-crud-operations","05.class-based-views/05.views-for-crud-operations",{"title":188,"path":189,"stem":190},"Handling Forms with Class-Based Views","/class-based-views/handling-forms-with-class-based-views","05.class-based-views/06.handling-forms-with-class-based-views",{"title":192,"path":193,"stem":194},"Using Mixins","/class-based-views/using-mixins","05.class-based-views/07.using-mixins",{"title":196,"path":197,"stem":198},"URL Configuration with Class-Based Views","/class-based-views/url-configuration-with-class-based-views","05.class-based-views/08.url-configuration-with-class-based-views",{"title":200,"path":201,"stem":202},"Subclassing Generic Views","/class-based-views/subclassing-generic-views","05.class-based-views/09.subclassing-generic-views",{"title":204,"path":205,"stem":206},"Asynchronous Class-Based Views","/class-based-views/asynchronous-class-based-views","05.class-based-views/10.asynchronous-class-based-views",{"title":208,"path":209,"stem":210},"Pagination","/class-based-views/pagination","05.class-based-views/11.pagination",{"title":212,"path":213,"stem":214,"children":215},"Forms and User Input","/forms-and-user-input","06.forms-and-user-input/01.index",[216,217,221,225,229,233,237,241,245,249],{"title":212,"path":213,"stem":214},{"title":218,"path":219,"stem":220},"Understanding HTML Forms","/forms-and-user-input/understanding-html-forms","06.forms-and-user-input/02.understanding-html-forms",{"title":222,"path":223,"stem":224},"Django's Role in Form Handling","/forms-and-user-input/djangos-role-in-form-handling","06.forms-and-user-input/03.djangos-role-in-form-handling",{"title":226,"path":227,"stem":228},"Creating Forms with Forms API","/forms-and-user-input/creating-forms-with-forms-api","06.forms-and-user-input/04.creating-forms-with-forms-api",{"title":230,"path":231,"stem":232},"Form Validation","/forms-and-user-input/form-validation","06.forms-and-user-input/05.form-validation",{"title":234,"path":235,"stem":236},"Built-in Fields and Widgets","/forms-and-user-input/built-in-fields-and-widgets","06.forms-and-user-input/06.built-in-fields-and-widgets",{"title":238,"path":239,"stem":240},"Form Rendering in Templates","/forms-and-user-input/form-rendering-in-templates","06.forms-and-user-input/07.form-rendering-in-templates",{"title":242,"path":243,"stem":244},"Model Forms","/forms-and-user-input/model-forms","06.forms-and-user-input/08.model-forms",{"title":246,"path":247,"stem":248},"Advanced Form Techniques","/forms-and-user-input/advanced-form-techniques","06.forms-and-user-input/09.advanced-form-techniques",{"title":250,"path":251,"stem":252},"Security Considerations for Forms","/forms-and-user-input/security-considerations-for-forms","06.forms-and-user-input/10.security-considerations-for-forms",{"title":254,"path":255,"stem":256,"children":257},"Models and Databases","/models-and-databases","07.models-and-databases/01.index",[258,259,263,267,271,275,279,283,287,291,295,299,303,307,311,315,319,323,327],{"title":254,"path":255,"stem":256},{"title":260,"path":261,"stem":262},"Understanding Django Models","/models-and-databases/understanding-django-models","07.models-and-databases/02.understanding-django-models",{"title":264,"path":265,"stem":266},"Defining Fields","/models-and-databases/defining-fields","07.models-and-databases/03.defining-fields",{"title":268,"path":269,"stem":270},"Relationships and Foreign Keys","/models-and-databases/relationships-and-foreign-keys","07.models-and-databases/04.relationships-and-foreign-keys",{"title":272,"path":273,"stem":274},"Examples of Relationship Patterns","/models-and-databases/examples-of-relationship-patterns","07.models-and-databases/05.examples-of-relationship-patterns",{"title":276,"path":277,"stem":278},"Making Queries","/models-and-databases/making-queries","07.models-and-databases/06.making-queries",{"title":280,"path":281,"stem":282},"Filtering, Ordering, and Slicing","/models-and-databases/filtering-ordering-slicing","07.models-and-databases/07.filtering-ordering-slicing",{"title":284,"path":285,"stem":286},"Managers and QuerySets","/models-and-databases/managers-and-querysets","07.models-and-databases/08.managers-and-querysets",{"title":288,"path":289,"stem":290},"Aggregation","/models-and-databases/aggregation","07.models-and-databases/09.aggregation",{"title":292,"path":293,"stem":294},"Search","/models-and-databases/search","07.models-and-databases/10.search",{"title":296,"path":297,"stem":298},"Raw SQL Queries","/models-and-databases/raw-sql-queries","07.models-and-databases/11.raw-sql-queries",{"title":300,"path":301,"stem":302},"Transactions","/models-and-databases/transactions","07.models-and-databases/12.transactions",{"title":304,"path":305,"stem":306},"Multiple Databases","/models-and-databases/multiple-databases","07.models-and-databases/13.multiple-databases",{"title":308,"path":309,"stem":310},"Tablespaces","/models-and-databases/tablespaces","07.models-and-databases/14.tablespaces",{"title":312,"path":313,"stem":314},"Composite Primary Keys","/models-and-databases/composite-primary-keys","07.models-and-databases/15.composite-primary-keys",{"title":316,"path":317,"stem":318},"Database Instrumentation","/models-and-databases/database-instrumentation","07.models-and-databases/16.database-instrumentation",{"title":320,"path":321,"stem":322},"Database Optimization","/models-and-databases/database-optimization","07.models-and-databases/17.database-optimization",{"title":324,"path":325,"stem":326},"Fixtures","/models-and-databases/fixtures","07.models-and-databases/18.fixtures",{"title":328,"path":329,"stem":330},"Signals","/models-and-databases/signals","07.models-and-databases/19.signals",{"title":332,"path":333,"stem":334,"children":335},"Migrations","/migrations","08.migrations/01.index",[336,337,341,345,349,353,357,361,365,369,373,377,381,385],{"title":332,"path":333,"stem":334},{"title":338,"path":339,"stem":340},"How Migrations Work","/migrations/how-migrations-work","08.migrations/02.how-migrations-work",{"title":342,"path":343,"stem":344},"Management Commands","/migrations/management-commands","08.migrations/03.management-commands",{"title":346,"path":347,"stem":348},"Dependencies and Workflow","/migrations/dependencies-and-workflow","08.migrations/04.dependencies-and-workflow",{"title":350,"path":351,"stem":352},"Transaction Handling","/migrations/transaction-handling","08.migrations/05.transaction-handling",{"title":354,"path":355,"stem":356},"Adding Migrations to Apps","/migrations/adding-migrations-to-apps","08.migrations/06.adding-migrations-to-apps",{"title":358,"path":359,"stem":360},"Reversing Migrations","/migrations/reversing-migrations","08.migrations/07.reversing-migrations",{"title":362,"path":363,"stem":364},"Historical Models","/migrations/historical-models","08.migrations/08.historical-models",{"title":366,"path":367,"stem":368},"Considerations When Removing Fields","/migrations/considerations-when-removing-fields","08.migrations/09.considerations-when-removing-fields",{"title":370,"path":371,"stem":372},"Data Migrations","/migrations/data-migrations","08.migrations/10.data-migrations",{"title":374,"path":375,"stem":376},"Squashing Migrations","/migrations/squashing-migrations","08.migrations/11.squashing-migrations",{"title":378,"path":379,"stem":380},"Serializing Values","/migrations/serializing-values","08.migrations/12.serializing-values",{"title":382,"path":383,"stem":384},"Supporting Multiple Django Versions","/migrations/supporting-multiple-django-versions","08.migrations/13.supporting-multiple-django-versions",{"title":386,"path":387,"stem":388},"Django Serialization Framework","/migrations/django-serialization-framework","08.migrations/14.django-serialization-framework",{"title":390,"path":391,"stem":392,"children":393},"Authentication and Authorization","/authentication-and-authorization","09.authentication-and-authorization/01.index",[394,395,399,403,407,411,415,419,423,427,431,435],{"title":390,"path":391,"stem":392},{"title":396,"path":397,"stem":398},"Overview of Django's Authentication System","/authentication-and-authorization/overview-of-django-authentication-system","09.authentication-and-authorization/02.overview-of-django-authentication-system",{"title":400,"path":401,"stem":402},"Users and Groups","/authentication-and-authorization/users-and-groups","09.authentication-and-authorization/03.users-and-groups",{"title":404,"path":405,"stem":406},"Permissions","/authentication-and-authorization/permissions","09.authentication-and-authorization/04.permissions",{"title":408,"path":409,"stem":410},"Password Management","/authentication-and-authorization/password-management","09.authentication-and-authorization/05.password-management",{"title":412,"path":413,"stem":414},"Authentication Views","/authentication-and-authorization/authentication-views","09.authentication-and-authorization/06.authentication-views",{"title":416,"path":417,"stem":418},"Login and Logout","/authentication-and-authorization/login-and-logout","09.authentication-and-authorization/07.login-and-logout",{"title":420,"path":421,"stem":422},"Custom User Models","/authentication-and-authorization/custom-user-models","09.authentication-and-authorization/08.custom-user-models",{"title":424,"path":425,"stem":426},"Middleware for Authentication","/authentication-and-authorization/middleware-for-authentication","09.authentication-and-authorization/09.middleware-for-authentication",{"title":428,"path":429,"stem":430},"Authorization in Views and Templates","/authentication-and-authorization/authorization-in-views-and-templates","09.authentication-and-authorization/10.authorization-in-views-and-templates",{"title":432,"path":433,"stem":434},"Integrating Social Authentication","/authentication-and-authorization/integrating-social-authentication","09.authentication-and-authorization/11.integrating-social-authentication",{"title":436,"path":437,"stem":438},"Security Best Practices","/authentication-and-authorization/security-best-practices","09.authentication-and-authorization/12.security-best-practices",{"title":440,"path":441,"stem":442,"children":443},"Sessions, Cookies, and State","/sessions-cookies-state","10.sessions-cookies-state/01.index",[444,446,450,454,458],{"title":445,"path":441,"stem":442},"Sessions, Cookies, and State Management",{"title":447,"path":448,"stem":449},"Introduction to Sessions","/sessions-cookies-state/introduction-to-sessions","10.sessions-cookies-state/02.introduction-to-sessions",{"title":451,"path":452,"stem":453},"Working with Cookies","/sessions-cookies-state/working-with-cookies","10.sessions-cookies-state/03.working-with-cookies",{"title":455,"path":456,"stem":457},"Server-Side Session Storage Options","/sessions-cookies-state/server-side-session-storage-options","10.sessions-cookies-state/04.server-side-session-storage-options",{"title":459,"path":460,"stem":461},"Session Security","/sessions-cookies-state/session-security","10.sessions-cookies-state/05.session-security",{"title":463,"path":464,"stem":465,"children":466},"Working with Files","/working-with-files","11.working-with-files/01.index",[467,468,472,476,480,484],{"title":463,"path":464,"stem":465},{"title":469,"path":470,"stem":471},"Files in Models","/working-with-files/files-in-models","11.working-with-files/02.files-in-models",{"title":473,"path":474,"stem":475},"The File Object","/working-with-files/the-file-object","11.working-with-files/03.the-file-object",{"title":477,"path":478,"stem":479},"Storage Backends","/working-with-files/storage-backends","11.working-with-files/04.storage-backends",{"title":481,"path":482,"stem":483},"Using Cloud Storage Providers","/working-with-files/using-cloud-storage-providers","11.working-with-files/05.using-cloud-storage-providers",{"title":485,"path":486,"stem":487},"Managing Media in Production","/working-with-files/managing-media-in-production","11.working-with-files/06.managing-media-in-production",{"title":489,"path":490,"stem":491,"children":492},"Admin Site","/admin-site","12.admin-site/01.index",[493,494,498,502,506,510],{"title":489,"path":490,"stem":491},{"title":495,"path":496,"stem":497},"Enabling the Admin","/admin-site/enabling-the-admin","12.admin-site/02.enabling-the-admin",{"title":499,"path":500,"stem":501},"Registering Models","/admin-site/registering-models","12.admin-site/03.registering-models",{"title":503,"path":504,"stem":505},"Customizing Admin Display","/admin-site/customizing-admin-display","12.admin-site/04.customizing-admin-display",{"title":507,"path":508,"stem":509},"Admin Actions","/admin-site/admin-actions","12.admin-site/05.admin-actions",{"title":511,"path":512,"stem":513},"Admin Security Best Practices","/admin-site/admin-security-best-practices","12.admin-site/06.admin-security-best-practices",{"title":515,"path":516,"stem":517,"children":518},"Middleware","/middleware","13.middleware/01.index",[519,520,524,528,532,536],{"title":515,"path":516,"stem":517},{"title":521,"path":522,"stem":523},"Middleware Overview","/middleware/middleware-overview","13.middleware/02.middleware-overview",{"title":525,"path":526,"stem":527},"Built-in Middleware","/middleware/built-in-middleware","13.middleware/03.built-in-middleware",{"title":529,"path":530,"stem":531},"Creating Custom Middleware","/middleware/creating-custom-middleware","13.middleware/04.creating-custom-middleware",{"title":533,"path":534,"stem":535},"Middleware Ordering","/middleware/middleware-ordering","13.middleware/05.middleware-ordering",{"title":537,"path":538,"stem":539},"Performance and Debugging","/middleware/performance-and-debugging","13.middleware/06.performance-and-debugging",{"title":541,"path":542,"stem":543,"children":544},"Security","/security","14.security/01.index",[545,546,550,554,558,562,566,570,574],{"title":541,"path":542,"stem":543},{"title":547,"path":548,"stem":549},"Django Security Philosophy","/security/django-security-philosophy","14.security/02.django-security-philosophy",{"title":551,"path":552,"stem":553},"Cross Site Request Forgery","/security/cross-site-request-forgery","14.security/03.cross-site-request-forgery",{"title":555,"path":556,"stem":557},"Cross Site Scripting","/security/cross-site-scripting","14.security/04.cross-site-scripting",{"title":559,"path":560,"stem":561},"SQL Injection Protection","/security/sql-injection-protection","14.security/05.sql-injection-protection",{"title":563,"path":564,"stem":565},"Clickjacking Protection","/security/clickjacking-protection","14.security/06.clickjacking-protection",{"title":567,"path":568,"stem":569},"HTTPS Setup and HSTS","/security/https-setup-and-hsts","14.security/07.https-setup-and-hsts",{"title":571,"path":572,"stem":573},"Password Storage and Cryptography","/security/password-storage-and-cryptography","14.security/08.password-storage-and-cryptography",{"title":575,"path":576,"stem":577},"Secure Deployment Checklist","/security/secure-deployment-checklist","14.security/09.secure-deployment-checklist",{"title":579,"path":580,"stem":581,"children":582},"Testing","/testing","15.testing/01.index",[583,584,588,592,596,600,604,608,612,616,620],{"title":579,"path":580,"stem":581},{"title":585,"path":586,"stem":587},"Introduction to Django Testing","/testing/introduction-to-django-testing","15.testing/02.introduction-to-django-testing",{"title":589,"path":590,"stem":591},"Writing and Running Tests","/testing/writing-and-running-tests","15.testing/03.writing-and-running-tests",{"title":593,"path":594,"stem":595},"Test Tools","/testing/test-tools","15.testing/04.test-tools",{"title":597,"path":598,"stem":599},"Testing Models","/testing/testing-models","15.testing/05.testing-models",{"title":601,"path":602,"stem":603},"Testing Views","/testing/testing-views","15.testing/06.testing-views",{"title":605,"path":606,"stem":607},"Testing Forms","/testing/testing-forms","15.testing/07.testing-forms",{"title":609,"path":610,"stem":611},"Testing Templates","/testing/testing-templates","15.testing/08.testing-templates",{"title":613,"path":614,"stem":615},"Testing Authentication","/testing/testing-authentication","15.testing/09.testing-authentication",{"title":617,"path":618,"stem":619},"Advanced Testing Topics","/testing/advanced-testing-topics","15.testing/10.advanced-testing-topics",{"title":621,"path":622,"stem":623},"Performance Testing","/testing/performance-testing","15.testing/11.performance-testing",{"title":625,"path":626,"stem":627,"children":628},"Static Assets and Frontend Integration","/static-assets-and-frontend-integration","16.static-assets-and-frontend-integration/01.index",[629,630,634,638,642,646],{"title":625,"path":626,"stem":627},{"title":631,"path":632,"stem":633},"Working with Static Files","/static-assets-and-frontend-integration/working-with-static-files","16.static-assets-and-frontend-integration/02.working-with-static-files",{"title":635,"path":636,"stem":637},"Integrating CSS and JavaScript","/static-assets-and-frontend-integration/integrating-css-and-javascript","16.static-assets-and-frontend-integration/03.integrating-css-and-javascript",{"title":639,"path":640,"stem":641},"Using Build Tools like Vite or Webpack","/static-assets-and-frontend-integration/using-build-tools-like-vite-or-webpack","16.static-assets-and-frontend-integration/04.using-build-tools-like-vite-or-webpack",{"title":643,"path":644,"stem":645},"Using React or Vue with Django","/static-assets-and-frontend-integration/using-react-or-vue-with-django","16.static-assets-and-frontend-integration/05.using-react-or-vue-with-django",{"title":647,"path":648,"stem":649},"Managing CORS","/static-assets-and-frontend-integration/managing-cors","16.static-assets-and-frontend-integration/06.managing-cors",{"title":651,"path":652,"stem":653,"children":654},"Internationalization and Localization","/internationalization-and-localization","17.internationalization-and-localization/01.index",[655,656,660,664,668],{"title":651,"path":652,"stem":653},{"title":657,"path":658,"stem":659},"Enabling Translation","/internationalization-and-localization/enabling-translation","17.internationalization-and-localization/02.enabling-translation",{"title":661,"path":662,"stem":663},"Translating Text in Code and Templates","/internationalization-and-localization/translating-text-in-code-and-templates","17.internationalization-and-localization/03.translating-text-in-code-and-templates",{"title":665,"path":666,"stem":667},"Timezone Support","/internationalization-and-localization/timezone-support","17.internationalization-and-localization/04.timezone-support",{"title":669,"path":670,"stem":671},"Locale Middleware","/internationalization-and-localization/locale-middleware","17.internationalization-and-localization/05.locale-middleware",{"title":673,"path":674,"stem":675,"children":676},"Caching","/caching","18.caching/01.index",[677,678,682,686,690,694,698],{"title":673,"path":674,"stem":675},{"title":679,"path":680,"stem":681},"Introduction to Caching","/caching/introduction-to-caching","18.caching/02.introduction-to-caching",{"title":683,"path":684,"stem":685},"Cache Backends","/caching/cache-backends","18.caching/03.cache-backends",{"title":687,"path":688,"stem":689},"Per View Caching","/caching/per-view-caching","18.caching/04.per-view-caching",{"title":691,"path":692,"stem":693},"Low Level Cache API","/caching/low-level-cache-api","18.caching/05.low-level-cache-api",{"title":695,"path":696,"stem":697},"Template Fragment Caching","/caching/template-fragment-caching","18.caching/06.template-fragment-caching",{"title":699,"path":700,"stem":701},"Deployment Level Caching Patterns","/caching/deployment-level-caching-patterns","18.caching/07.deployment-level-caching-patterns",{"title":703,"path":704,"stem":705,"children":706},"Asynchronous Django","/asynchronous-django","19.asynchronous-django/01.index",[707,708,712,716,720,724,728,732],{"title":703,"path":704,"stem":705},{"title":709,"path":710,"stem":711},"Introduction to ASGI","/asynchronous-django/introduction-to-asgi","19.asynchronous-django/02.introduction-to-asgi",{"title":713,"path":714,"stem":715},"Async Views","/asynchronous-django/async-views","19.asynchronous-django/03.async-views",{"title":717,"path":718,"stem":719},"Async ORM Status","/asynchronous-django/async-orm-status","19.asynchronous-django/04.async-orm-status",{"title":721,"path":722,"stem":723},"WebSockets with Channels","/asynchronous-django/websockets-with-channels","19.asynchronous-django/05.websockets-with-channels",{"title":725,"path":726,"stem":727},"Background Tasks with Celery or RQ","/asynchronous-django/background-tasks-with-celery-or-rq","19.asynchronous-django/06.background-tasks-with-celery-or-rq",{"title":729,"path":730,"stem":731},"Asynchronous Support","/asynchronous-django/asynchronous-support","19.asynchronous-django/07.asynchronous-support",{"title":733,"path":734,"stem":735},"Django's Tasks Framework","/asynchronous-django/django-tasks-framework","19.asynchronous-django/08.django-tasks-framework",{"title":737,"path":738,"stem":739,"children":740},"Deployment","/deployment","20.deployment/01.index",[741,742,746,750,754,758,762,766,770],{"title":737,"path":738,"stem":739},{"title":743,"path":744,"stem":745},"Preparing for Production","/deployment/preparing-for-production","20.deployment/02.preparing-for-production",{"title":747,"path":748,"stem":749},"Using WSGI and ASGI Servers","/deployment/using-wsgi-and-asgi-servers","20.deployment/03.using-wsgi-and-asgi-servers",{"title":751,"path":752,"stem":753},"Deploying on Linux Servers","/deployment/deploying-on-linux-servers","20.deployment/04.deploying-on-linux-servers",{"title":755,"path":756,"stem":757},"Using Docker","/deployment/using-docker","20.deployment/05.using-docker",{"title":759,"path":760,"stem":761},"Cloud Deployment Guides","/deployment/cloud-deployment-guides","20.deployment/06.cloud-deployment-guides",{"title":763,"path":764,"stem":765},"Scaling and Load Balancing","/deployment/scaling-and-load-balancing","20.deployment/07.scaling-and-load-balancing",{"title":767,"path":768,"stem":769},"Monitoring and Logging","/deployment/monitoring-and-logging","20.deployment/08.monitoring-and-logging",{"title":771,"path":772,"stem":773},"Backup Strategies","/deployment/backup-strategies","20.deployment/09.backup-strategies",{"title":775,"path":776,"stem":777,"children":778},"Performance and Optimization","/performance-and-optimization","21.performance-and-optimization/01.index",[779,780,784,788,792,796],{"title":775,"path":776,"stem":777},{"title":781,"path":782,"stem":783},"Query Optimization","/performance-and-optimization/query-optimization","21.performance-and-optimization/02.query-optimization",{"title":785,"path":786,"stem":787},"Template Rendering Optimization","/performance-and-optimization/template-rendering-optimization","21.performance-and-optimization/03.template-rendering-optimization",{"title":789,"path":790,"stem":791},"Using Select Related and Prefetch Related","/performance-and-optimization/using-select-related-and-prefetch-related","21.performance-and-optimization/04.using-select-related-and-prefetch-related",{"title":793,"path":794,"stem":795},"Caching Strategies","/performance-and-optimization/caching-strategies","21.performance-and-optimization/05.caching-strategies",{"title":797,"path":798,"stem":799},"Profiling Django Apps","/performance-and-optimization/profiling-django-apps","21.performance-and-optimization/06.profiling-django-apps",{"title":801,"path":802,"stem":803,"children":804},"Advanced and Expert Topics","/advanced-and-expert-topics","22.advanced-and-expert-topics/01.index",[805,806,810,814,818,822,826,830,834,838,842,846],{"title":801,"path":802,"stem":803},{"title":807,"path":808,"stem":809},"System Architecture Patterns","/advanced-and-expert-topics/system-architecture-patterns","22.advanced-and-expert-topics/02.system-architecture-patterns",{"title":811,"path":812,"stem":813},"Domain Driven Design with Django","/advanced-and-expert-topics/domain-driven-design-with-django","22.advanced-and-expert-topics/03.domain-driven-design-with-django",{"title":815,"path":816,"stem":817},"Building Large Scale Django Projects","/advanced-and-expert-topics/building-large-scale-django-projects","22.advanced-and-expert-topics/04.building-large-scale-django-projects",{"title":819,"path":820,"stem":821},"Plugin Architectures for Django Apps","/advanced-and-expert-topics/plugin-architectures-for-django-apps","22.advanced-and-expert-topics/05.plugin-architectures-for-django-apps",{"title":823,"path":824,"stem":825},"Extending Django's Core","/advanced-and-expert-topics/extending-djangos-core","22.advanced-and-expert-topics/06.extending-djangos-core",{"title":827,"path":828,"stem":829},"Custom ORM Expressions","/advanced-and-expert-topics/custom-orm-expressions","22.advanced-and-expert-topics/07.custom-orm-expressions",{"title":831,"path":832,"stem":833},"Custom Management Commands","/advanced-and-expert-topics/custom-management-commands","22.advanced-and-expert-topics/08.custom-management-commands",{"title":835,"path":836,"stem":837},"Working with Signals","/advanced-and-expert-topics/working-with-signals","22.advanced-and-expert-topics/09.working-with-signals",{"title":839,"path":840,"stem":841},"Building Reusable Django Packages","/advanced-and-expert-topics/building-reusable-django-packages","22.advanced-and-expert-topics/10.building-reusable-django-packages",{"title":843,"path":844,"stem":845},"Integrating Microservices","/advanced-and-expert-topics/integrating-microservices","22.advanced-and-expert-topics/11.integrating-microservices",{"title":847,"path":848,"stem":849},"Advanced Security Hardening","/advanced-and-expert-topics/advanced-security-hardening","22.advanced-and-expert-topics/12.advanced-security-hardening",{"title":851,"path":852,"stem":853,"children":854},"Logging in Django","/logging-in-django","23.logging-in-django/01.index",[855],{"title":851,"path":852,"stem":853},{"title":857,"path":858,"stem":859,"children":860},"FAQ and Troubleshooting","/faq-and-troubleshooting","24.faq-and-troubleshooting/01.index",[861],{"title":857,"path":858,"stem":859},{"title":863,"path":864,"stem":865,"children":866},"External Packages and Ecosystem","/external-packages-and-ecosystem","25.external-packages-and-ecosystem/01.index",[867],{"title":863,"path":864,"stem":865},{"title":869,"path":870,"stem":871,"children":872},"Django Internals and Contributing","/django-internals-and-contributing","26.django-internals-and-contributing/01.index",[873],{"title":869,"path":870,"stem":871},{"title":875,"path":876,"stem":877,"children":878},"Microservices with Django","/microservices-with-django","27.microservices-with-django/01.index",[879,880,884,888,892,896,900,904,908,912,916,920,924],{"title":875,"path":876,"stem":877},{"title":881,"path":882,"stem":883},"What Is a Microservice?","/microservices-with-django/what-is-a-microservice","27.microservices-with-django/02.what-is-a-microservice",{"title":885,"path":886,"stem":887},"Introducing the Django Microservices Architecture","/microservices-with-django/django-microservices-architecture","27.microservices-with-django/03.django-microservices-architecture",{"title":889,"path":890,"stem":891},"Setting Up the Development and Runtime Environment","/microservices-with-django/development-environment","27.microservices-with-django/04.development-environment",{"title":893,"path":894,"stem":895},"Cloud-native Data Processing with MongoDB","/microservices-with-django/cloud-native-data-processing","27.microservices-with-django/05.cloud-native-data-processing",{"title":897,"path":898,"stem":899},"Creating RESTful APIs for Microservices","/microservices-with-django/restful-apis","27.microservices-with-django/06.restful-apis",{"title":901,"path":902,"stem":903},"Orchestrating Microservices with Celery and RabbitMQ","/microservices-with-django/orchestrating-celery-rabbitmq","27.microservices-with-django/07.orchestrating-celery-rabbitmq",{"title":905,"path":906,"stem":907},"Testing Microservices","/microservices-with-django/testing-microservices","27.microservices-with-django/08.testing-microservices",{"title":909,"path":910,"stem":911},"Deploying Microservices","/microservices-with-django/deploying-microservices","27.microservices-with-django/09.deploying-microservices",{"title":913,"path":914,"stem":915},"Securing Microservices","/microservices-with-django/securing-microservices","27.microservices-with-django/10.securing-microservices",{"title":917,"path":918,"stem":919},"Improving Microservices Performance with Caching","/microservices-with-django/performance-caching","27.microservices-with-django/11.performance-caching",{"title":921,"path":922,"stem":923},"Best Practices","/microservices-with-django/best-practices","27.microservices-with-django/12.best-practices",{"title":925,"path":926,"stem":927},"Transforming a Monolithic Web App into a Microservice version","/microservices-with-django/monolith-to-microservices","27.microservices-with-django/13.monolith-to-microservices",{"title":929,"path":930,"stem":931,"children":932},"Releases","/releases","releases",[933,936,940,944,948,952,956,960,964,968,972,976,980,984,988,992,996,1000,1004,1008,1012],{"title":934,"path":930,"stem":935},"Django Releases","releases/index",{"title":937,"path":938,"stem":939},"Django 5.1.10 release notes","/releases/5.1.10","releases/5.1.10",{"title":941,"path":942,"stem":943},"Django 5.1.11 release notes","/releases/5.1.11","releases/5.1.11",{"title":945,"path":946,"stem":947},"Django 5.1.12 release notes","/releases/5.1.12","releases/5.1.12",{"title":949,"path":950,"stem":951},"Django 5.1.13 release notes","/releases/5.1.13","releases/5.1.13",{"title":953,"path":954,"stem":955},"Django 5.1.14 release notes","/releases/5.1.14","releases/5.1.14",{"title":957,"path":958,"stem":959},"Django 5.1.15 release notes","/releases/5.1.15","releases/5.1.15",{"title":961,"path":962,"stem":963},"Django 5.2 release notes","/releases/5.2","releases/5.2",{"title":965,"path":966,"stem":967},"Django 5.2.1 release notes","/releases/5.2.1","releases/5.2.1",{"title":969,"path":970,"stem":971},"Django 5.2.10 release notes","/releases/5.2.10","releases/5.2.10",{"title":973,"path":974,"stem":975},"Django 5.2.2 release notes","/releases/5.2.2","releases/5.2.2",{"title":977,"path":978,"stem":979},"Django 5.2.3 release notes","/releases/5.2.3","releases/5.2.3",{"title":981,"path":982,"stem":983},"Django 5.2.4 release notes","/releases/5.2.4","releases/5.2.4",{"title":985,"path":986,"stem":987},"Django 5.2.5 release notes","/releases/5.2.5","releases/5.2.5",{"title":989,"path":990,"stem":991},"Django 5.2.6 release notes","/releases/5.2.6","releases/5.2.6",{"title":993,"path":994,"stem":995},"Django 5.2.7 release notes","/releases/5.2.7","releases/5.2.7",{"title":997,"path":998,"stem":999},"Django 5.2.8 release notes","/releases/5.2.8","releases/5.2.8",{"title":1001,"path":1002,"stem":1003},"Django 5.2.9 release notes","/releases/5.2.9","releases/5.2.9",{"title":1005,"path":1006,"stem":1007},"Django 6.0 release notes","/releases/6.0","releases/6.0",{"title":1009,"path":1010,"stem":1011},"Django 6.0.1 release notes","/releases/6.0.1","releases/6.0.1",{"title":1013,"path":1014,"stem":1015},"Django 6.1 release notes - UNDER DEVELOPMENT","/releases/6.1","releases/6.1",{"id":1017,"title":621,"body":1018,"description":1028,"extension":16051,"links":16052,"meta":16053,"navigation":1182,"path":622,"seo":16054,"stem":623,"__hash__":16055},"docs/15.testing/11.performance-testing.md",{"type":1019,"value":1020,"toc":16030},"minimark",[1021,1025,1029,1034,1039,5191,5195,5199,6914,6918,6922,9952,9956,9960,12397,12401,12405,14058,14062,14066,15961,15965,15968,16003,16006,16023,16026],[1022,1023,621],"h1",{"id":1024},"performance-testing",[1026,1027,1028],"p",{},"Performance testing ensures your Django application can handle expected loads, responds quickly under various conditions, and scales effectively. This chapter covers load testing, stress testing, profiling, and optimization strategies to maintain optimal application performance.",[1030,1031,1033],"h2",{"id":1032},"load-testing-fundamentals","Load Testing Fundamentals",[1035,1036,1038],"h3",{"id":1037},"setting-up-load-testing","Setting Up Load Testing",[1040,1041,1046],"pre",{"className":1042,"code":1043,"language":1044,"meta":1045,"style":1045},"language-python shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","import time\nimport threading\nimport statistics\nfrom concurrent.futures import ThreadPoolExecutor, as_completed\nfrom django.test import TestCase, Client\nfrom django.test.utils import override_settings\nfrom django.contrib.auth.models import User\n\nclass LoadTestingBase(TestCase):\n    \"\"\"Base class for load testing\"\"\"\n    \n    def setUp(self):\n        \"\"\"Set up test data for load testing\"\"\"\n        \n        # Create test users\n        self.users = []\n        for i in range(10):\n            user = User.objects.create_user(\n                username=f'user{i}',\n                email=f'user{i}@example.com',\n                password='testpass123'\n            )\n            self.users.append(user)\n        \n        # Create test data\n        from blog.models import BlogPost, Category\n        self.category = Category.objects.create(name='Tech', slug='tech')\n        \n        # Create multiple posts for realistic load testing\n        self.posts = []\n        for i in range(100):\n            post = BlogPost.objects.create(\n                title=f'Load Test Post {i}',\n                content=f'Content for load test post {i}. ' * 50,  # Longer content\n                author=self.users[i % len(self.users)],\n                category=self.category,\n                status='published'\n            )\n            self.posts.append(post)\n    \n    def make_request(self, url, method='GET', data=None, user=None):\n        \"\"\"Make a single HTTP request and measure performance\"\"\"\n        \n        client = Client()\n        \n        # Login if user provided\n        if user:\n            client.force_login(user)\n        \n        start_time = time.time()\n        \n        try:\n            if method == 'GET':\n                response = client.get(url)\n            elif method == 'POST':\n                response = client.post(url, data or {})\n            else:\n                raise ValueError(f\"Unsupported method: {method}\")\n            \n            end_time = time.time()\n            \n            return {\n                'status_code': response.status_code,\n                'response_time': end_time - start_time,\n                'success': 200 \u003C= response.status_code \u003C 400,\n                'content_length': len(response.content),\n                'error': None\n            }\n            \n        except Exception as e:\n            end_time = time.time()\n            return {\n                'status_code': 500,\n                'response_time': end_time - start_time,\n                'success': False,\n                'content_length': 0,\n                'error': str(e)\n            }\n    \n    def run_load_test(self, url, num_requests=100, concurrent_users=10, \n                      method='GET', data=None, authenticated=False):\n        \"\"\"Run load test with specified parameters\"\"\"\n        \n        results = []\n        \n        def worker():\n            \"\"\"Worker function for each thread\"\"\"\n            user = None\n            if authenticated and self.users:\n                # Assign user in round-robin fashion\n                user_index = threading.current_thread().ident % len(self.users)\n                user = self.users[user_index]\n            \n            return self.make_request(url, method, data, user)\n        \n        # Execute concurrent requests\n        with ThreadPoolExecutor(max_workers=concurrent_users) as executor:\n            # Submit all requests\n            futures = [executor.submit(worker) for _ in range(num_requests)]\n            \n            # Collect results\n            for future in as_completed(futures):\n                try:\n                    result = future.result(timeout=30)  # 30 second timeout\n                    results.append(result)\n                except Exception as e:\n                    results.append({\n                        'status_code': 500,\n                        'response_time': 30.0,\n                        'success': False,\n                        'content_length': 0,\n                        'error': f\"Request timeout or error: {e}\"\n                    })\n        \n        return self.analyze_results(results)\n    \n    def analyze_results(self, results):\n        \"\"\"Analyze load test results\"\"\"\n        \n        if not results:\n            return {'error': 'No results to analyze'}\n        \n        # Extract metrics\n        response_times = [r['response_time'] for r in results]\n        successful_requests = [r for r in results if r['success']]\n        failed_requests = [r for r in results if not r['success']]\n        \n        # Calculate statistics\n        analysis = {\n            'total_requests': len(results),\n            'successful_requests': len(successful_requests),\n            'failed_requests': len(failed_requests),\n            'success_rate': len(successful_requests) / len(results) * 100,\n            \n            # Response time statistics\n            'avg_response_time': statistics.mean(response_times),\n            'min_response_time': min(response_times),\n            'max_response_time': max(response_times),\n            'median_response_time': statistics.median(response_times),\n            \n            # Percentiles\n            'p95_response_time': self.percentile(response_times, 95),\n            'p99_response_time': self.percentile(response_times, 99),\n            \n            # Throughput\n            'requests_per_second': len(results) / sum(response_times) * len(results),\n            \n            # Error analysis\n            'errors': [r['error'] for r in failed_requests if r['error']],\n            'status_codes': self.count_status_codes(results)\n        }\n        \n        return analysis\n    \n    def percentile(self, data, percentile):\n        \"\"\"Calculate percentile of data\"\"\"\n        sorted_data = sorted(data)\n        index = int(len(sorted_data) * percentile / 100)\n        return sorted_data[min(index, len(sorted_data) - 1)]\n    \n    def count_status_codes(self, results):\n        \"\"\"Count occurrences of each status code\"\"\"\n        status_counts = {}\n        for result in results:\n            code = result['status_code']\n            status_counts[code] = status_counts.get(code, 0) + 1\n        return status_counts\n\nclass BasicLoadTests(LoadTestingBase):\n    \"\"\"Basic load testing scenarios\"\"\"\n    \n    def test_homepage_load(self):\n        \"\"\"Test homepage under load\"\"\"\n        \n        results = self.run_load_test(\n            url='/',\n            num_requests=50,\n            concurrent_users=5\n        )\n        \n        # Assert performance requirements\n        self.assertGreaterEqual(results['success_rate'], 95.0)\n        self.assertLess(results['avg_response_time'], 2.0)  # \u003C 2 seconds\n        self.assertLess(results['p95_response_time'], 5.0)  # 95% \u003C 5 seconds\n        self.assertGreater(results['requests_per_second'], 10)  # > 10 RPS\n        \n        print(f\"Homepage Load Test Results:\")\n        print(f\"Success Rate: {results['success_rate']:.1f}%\")\n        print(f\"Average Response Time: {results['avg_response_time']:.3f}s\")\n        print(f\"95th Percentile: {results['p95_response_time']:.3f}s\")\n        print(f\"Requests/Second: {results['requests_per_second']:.1f}\")\n    \n    def test_blog_list_load(self):\n        \"\"\"Test blog list page under load\"\"\"\n        \n        results = self.run_load_test(\n            url='/blog/',\n            num_requests=100,\n            concurrent_users=10\n        )\n        \n        # Blog list might be slower due to database queries\n        self.assertGreaterEqual(results['success_rate'], 90.0)\n        self.assertLess(results['avg_response_time'], 3.0)\n        self.assertLess(results['p95_response_time'], 8.0)\n        \n        print(f\"Blog List Load Test Results:\")\n        print(f\"Success Rate: {results['success_rate']:.1f}%\")\n        print(f\"Average Response Time: {results['avg_response_time']:.3f}s\")\n        print(f\"Failed Requests: {results['failed_requests']}\")\n    \n    def test_post_detail_load(self):\n        \"\"\"Test individual post pages under load\"\"\"\n        \n        # Test multiple different posts\n        post_urls = [f'/blog/{post.slug}/' for post in self.posts[:10]]\n        \n        all_results = []\n        for url in post_urls:\n            results = self.run_load_test(\n                url=url,\n                num_requests=20,\n                concurrent_users=5\n            )\n            all_results.append(results)\n        \n        # Analyze combined results\n        avg_success_rate = sum(r['success_rate'] for r in all_results) / len(all_results)\n        avg_response_time = sum(r['avg_response_time'] for r in all_results) / len(all_results)\n        \n        self.assertGreaterEqual(avg_success_rate, 95.0)\n        self.assertLess(avg_response_time, 2.0)\n        \n        print(f\"Post Detail Load Test Results (10 different posts):\")\n        print(f\"Average Success Rate: {avg_success_rate:.1f}%\")\n        print(f\"Average Response Time: {avg_response_time:.3f}s\")\n    \n    def test_authenticated_user_load(self):\n        \"\"\"Test load with authenticated users\"\"\"\n        \n        results = self.run_load_test(\n            url='/dashboard/',\n            num_requests=50,\n            concurrent_users=5,\n            authenticated=True\n        )\n        \n        # Authenticated requests might be slower due to session handling\n        self.assertGreaterEqual(results['success_rate'], 90.0)\n        self.assertLess(results['avg_response_time'], 3.0)\n        \n        print(f\"Authenticated User Load Test Results:\")\n        print(f\"Success Rate: {results['success_rate']:.1f}%\")\n        print(f\"Average Response Time: {results['avg_response_time']:.3f}s\")\n","python","",[1047,1048,1049,1062,1070,1078,1105,1128,1150,1177,1184,1205,1219,1225,1243,1254,1260,1267,1286,1310,1336,1368,1391,1408,1414,1437,1442,1448,1471,1525,1530,1536,1550,1568,1588,1611,1645,1682,1698,1713,1718,1738,1743,1797,1807,1812,1826,1831,1837,1848,1865,1870,1888,1893,1901,1922,1945,1964,1992,2000,2029,2035,2051,2056,2065,2088,2111,2143,2170,2185,2191,2196,2213,2228,2235,2251,2270,2286,2302,2323,2328,2333,2372,2406,2416,2421,2431,2436,2448,2459,2468,2488,2494,2531,2553,2558,2588,2593,2599,2627,2633,2677,2682,2688,2709,2717,2748,2764,2778,2790,2806,2822,2837,2852,2878,2884,2889,2909,2914,2933,2943,2948,2960,2986,2991,2997,3032,3072,3108,3113,3119,3129,3150,3170,3190,3228,3233,3239,3266,3287,3308,3333,3338,3344,3374,3403,3408,3414,3455,3460,3466,3516,3541,3547,3552,3560,3565,3587,3597,3615,3650,3686,3691,3709,3719,3730,3744,3765,3802,3810,3815,3830,3840,3845,3859,3869,3874,3890,3906,3919,3930,3936,3941,3947,3977,4009,4040,4072,4077,4092,4128,4164,4198,4232,4237,4251,4261,4266,4281,4297,4308,4318,4323,4328,4334,4362,4390,4418,4423,4437,4470,4503,4535,4540,4554,4564,4569,4575,4624,4629,4639,4654,4670,4682,4695,4705,4710,4726,4731,4737,4783,4827,4832,4852,4871,4876,4890,4914,4937,4942,4956,4966,4971,4986,5002,5013,5025,5036,5041,5046,5052,5079,5106,5111,5125,5158],"code",{"__ignoreMap":1045},[1050,1051,1054,1058],"span",{"class":1052,"line":1053},"line",1,[1050,1055,1057],{"class":1056},"siDh9","import",[1050,1059,1061],{"class":1060},"sftqT"," time\n",[1050,1063,1065,1067],{"class":1052,"line":1064},2,[1050,1066,1057],{"class":1056},[1050,1068,1069],{"class":1060}," threading\n",[1050,1071,1073,1075],{"class":1052,"line":1072},3,[1050,1074,1057],{"class":1056},[1050,1076,1077],{"class":1060}," statistics\n",[1050,1079,1081,1084,1087,1091,1094,1096,1099,1102],{"class":1052,"line":1080},4,[1050,1082,1083],{"class":1056},"from",[1050,1085,1086],{"class":1060}," concurrent",[1050,1088,1090],{"class":1089},"soVBu",".",[1050,1092,1093],{"class":1060},"futures ",[1050,1095,1057],{"class":1056},[1050,1097,1098],{"class":1060}," ThreadPoolExecutor",[1050,1100,1101],{"class":1089},",",[1050,1103,1104],{"class":1060}," as_completed\n",[1050,1106,1108,1110,1113,1115,1118,1120,1123,1125],{"class":1052,"line":1107},5,[1050,1109,1083],{"class":1056},[1050,1111,1112],{"class":1060}," django",[1050,1114,1090],{"class":1089},[1050,1116,1117],{"class":1060},"test ",[1050,1119,1057],{"class":1056},[1050,1121,1122],{"class":1060}," TestCase",[1050,1124,1101],{"class":1089},[1050,1126,1127],{"class":1060}," Client\n",[1050,1129,1131,1133,1135,1137,1140,1142,1145,1147],{"class":1052,"line":1130},6,[1050,1132,1083],{"class":1056},[1050,1134,1112],{"class":1060},[1050,1136,1090],{"class":1089},[1050,1138,1139],{"class":1060},"test",[1050,1141,1090],{"class":1089},[1050,1143,1144],{"class":1060},"utils ",[1050,1146,1057],{"class":1056},[1050,1148,1149],{"class":1060}," override_settings\n",[1050,1151,1153,1155,1157,1159,1162,1164,1167,1169,1172,1174],{"class":1052,"line":1152},7,[1050,1154,1083],{"class":1056},[1050,1156,1112],{"class":1060},[1050,1158,1090],{"class":1089},[1050,1160,1161],{"class":1060},"contrib",[1050,1163,1090],{"class":1089},[1050,1165,1166],{"class":1060},"auth",[1050,1168,1090],{"class":1089},[1050,1170,1171],{"class":1060},"models ",[1050,1173,1057],{"class":1056},[1050,1175,1176],{"class":1060}," User\n",[1050,1178,1180],{"class":1052,"line":1179},8,[1050,1181,1183],{"emptyLinePlaceholder":1182},true,"\n",[1050,1185,1187,1191,1195,1198,1202],{"class":1052,"line":1186},9,[1050,1188,1190],{"class":1189},"s5Kfy","class",[1050,1192,1194],{"class":1193},"sD-vU"," LoadTestingBase",[1050,1196,1197],{"class":1089},"(",[1050,1199,1201],{"class":1200},"sYn-s","TestCase",[1050,1203,1204],{"class":1089},"):\n",[1050,1206,1208,1212,1216],{"class":1052,"line":1207},10,[1050,1209,1211],{"class":1210},"sm7ve","    \"\"\"",[1050,1213,1215],{"class":1214},"sVyVU","Base class for load testing",[1050,1217,1218],{"class":1210},"\"\"\"\n",[1050,1220,1222],{"class":1052,"line":1221},11,[1050,1223,1224],{"class":1060},"    \n",[1050,1226,1228,1231,1235,1237,1241],{"class":1052,"line":1227},12,[1050,1229,1230],{"class":1189},"    def",[1050,1232,1234],{"class":1233},"sljsM"," setUp",[1050,1236,1197],{"class":1089},[1050,1238,1240],{"class":1239},"sRjD_","self",[1050,1242,1204],{"class":1089},[1050,1244,1246,1249,1252],{"class":1052,"line":1245},13,[1050,1247,1248],{"class":1210},"        \"\"\"",[1050,1250,1251],{"class":1214},"Set up test data for load testing",[1050,1253,1218],{"class":1210},[1050,1255,1257],{"class":1052,"line":1256},14,[1050,1258,1259],{"class":1060},"        \n",[1050,1261,1263],{"class":1052,"line":1262},15,[1050,1264,1266],{"class":1265},"s9Tkl","        # Create test users\n",[1050,1268,1270,1274,1276,1280,1283],{"class":1052,"line":1269},16,[1050,1271,1273],{"class":1272},"se3Ec","        self",[1050,1275,1090],{"class":1089},[1050,1277,1279],{"class":1278},"sBPpx","users",[1050,1281,1282],{"class":1089}," =",[1050,1284,1285],{"class":1089}," []\n",[1050,1287,1289,1292,1295,1298,1302,1304,1308],{"class":1052,"line":1288},17,[1050,1290,1291],{"class":1056},"        for",[1050,1293,1294],{"class":1060}," i ",[1050,1296,1297],{"class":1056},"in",[1050,1299,1301],{"class":1300},"sJdAF"," range",[1050,1303,1197],{"class":1089},[1050,1305,1307],{"class":1306},"s7CZa","10",[1050,1309,1204],{"class":1089},[1050,1311,1313,1316,1319,1322,1324,1327,1329,1333],{"class":1052,"line":1312},18,[1050,1314,1315],{"class":1060},"            user ",[1050,1317,1318],{"class":1089},"=",[1050,1320,1321],{"class":1060}," User",[1050,1323,1090],{"class":1089},[1050,1325,1326],{"class":1278},"objects",[1050,1328,1090],{"class":1089},[1050,1330,1332],{"class":1331},"siWMO","create_user",[1050,1334,1335],{"class":1089},"(\n",[1050,1337,1339,1343,1345,1348,1352,1356,1359,1362,1365],{"class":1052,"line":1338},19,[1050,1340,1342],{"class":1341},"sqOPj","                username",[1050,1344,1318],{"class":1089},[1050,1346,1347],{"class":1189},"f",[1050,1349,1351],{"class":1350},"sTbE_","'user",[1050,1353,1355],{"class":1354},"s3h35","{",[1050,1357,1358],{"class":1331},"i",[1050,1360,1361],{"class":1354},"}",[1050,1363,1364],{"class":1350},"'",[1050,1366,1367],{"class":1089},",\n",[1050,1369,1371,1374,1376,1378,1380,1382,1384,1386,1389],{"class":1052,"line":1370},20,[1050,1372,1373],{"class":1341},"                email",[1050,1375,1318],{"class":1089},[1050,1377,1347],{"class":1189},[1050,1379,1351],{"class":1350},[1050,1381,1355],{"class":1354},[1050,1383,1358],{"class":1331},[1050,1385,1361],{"class":1354},[1050,1387,1388],{"class":1350},"@example.com'",[1050,1390,1367],{"class":1089},[1050,1392,1394,1397,1399,1402,1405],{"class":1052,"line":1393},21,[1050,1395,1396],{"class":1341},"                password",[1050,1398,1318],{"class":1089},[1050,1400,1364],{"class":1401},"sbYkP",[1050,1403,1404],{"class":1350},"testpass123",[1050,1406,1407],{"class":1401},"'\n",[1050,1409,1411],{"class":1052,"line":1410},22,[1050,1412,1413],{"class":1089},"            )\n",[1050,1415,1417,1420,1422,1424,1426,1429,1431,1434],{"class":1052,"line":1416},23,[1050,1418,1419],{"class":1272},"            self",[1050,1421,1090],{"class":1089},[1050,1423,1279],{"class":1278},[1050,1425,1090],{"class":1089},[1050,1427,1428],{"class":1331},"append",[1050,1430,1197],{"class":1089},[1050,1432,1433],{"class":1331},"user",[1050,1435,1436],{"class":1089},")\n",[1050,1438,1440],{"class":1052,"line":1439},24,[1050,1441,1259],{"class":1060},[1050,1443,1445],{"class":1052,"line":1444},25,[1050,1446,1447],{"class":1265},"        # Create test data\n",[1050,1449,1451,1454,1457,1459,1461,1463,1466,1468],{"class":1052,"line":1450},26,[1050,1452,1453],{"class":1056},"        from",[1050,1455,1456],{"class":1060}," blog",[1050,1458,1090],{"class":1089},[1050,1460,1171],{"class":1060},[1050,1462,1057],{"class":1056},[1050,1464,1465],{"class":1060}," BlogPost",[1050,1467,1101],{"class":1089},[1050,1469,1470],{"class":1060}," Category\n",[1050,1472,1474,1476,1478,1481,1483,1486,1488,1490,1492,1495,1497,1500,1502,1504,1507,1509,1511,1514,1516,1518,1521,1523],{"class":1052,"line":1473},27,[1050,1475,1273],{"class":1272},[1050,1477,1090],{"class":1089},[1050,1479,1480],{"class":1278},"category",[1050,1482,1282],{"class":1089},[1050,1484,1485],{"class":1060}," Category",[1050,1487,1090],{"class":1089},[1050,1489,1326],{"class":1278},[1050,1491,1090],{"class":1089},[1050,1493,1494],{"class":1331},"create",[1050,1496,1197],{"class":1089},[1050,1498,1499],{"class":1341},"name",[1050,1501,1318],{"class":1089},[1050,1503,1364],{"class":1401},[1050,1505,1506],{"class":1350},"Tech",[1050,1508,1364],{"class":1401},[1050,1510,1101],{"class":1089},[1050,1512,1513],{"class":1341}," slug",[1050,1515,1318],{"class":1089},[1050,1517,1364],{"class":1401},[1050,1519,1520],{"class":1350},"tech",[1050,1522,1364],{"class":1401},[1050,1524,1436],{"class":1089},[1050,1526,1528],{"class":1052,"line":1527},28,[1050,1529,1259],{"class":1060},[1050,1531,1533],{"class":1052,"line":1532},29,[1050,1534,1535],{"class":1265},"        # Create multiple posts for realistic load testing\n",[1050,1537,1539,1541,1543,1546,1548],{"class":1052,"line":1538},30,[1050,1540,1273],{"class":1272},[1050,1542,1090],{"class":1089},[1050,1544,1545],{"class":1278},"posts",[1050,1547,1282],{"class":1089},[1050,1549,1285],{"class":1089},[1050,1551,1553,1555,1557,1559,1561,1563,1566],{"class":1052,"line":1552},31,[1050,1554,1291],{"class":1056},[1050,1556,1294],{"class":1060},[1050,1558,1297],{"class":1056},[1050,1560,1301],{"class":1300},[1050,1562,1197],{"class":1089},[1050,1564,1565],{"class":1306},"100",[1050,1567,1204],{"class":1089},[1050,1569,1571,1574,1576,1578,1580,1582,1584,1586],{"class":1052,"line":1570},32,[1050,1572,1573],{"class":1060},"            post ",[1050,1575,1318],{"class":1089},[1050,1577,1465],{"class":1060},[1050,1579,1090],{"class":1089},[1050,1581,1326],{"class":1278},[1050,1583,1090],{"class":1089},[1050,1585,1494],{"class":1331},[1050,1587,1335],{"class":1089},[1050,1589,1591,1594,1596,1598,1601,1603,1605,1607,1609],{"class":1052,"line":1590},33,[1050,1592,1593],{"class":1341},"                title",[1050,1595,1318],{"class":1089},[1050,1597,1347],{"class":1189},[1050,1599,1600],{"class":1350},"'Load Test Post ",[1050,1602,1355],{"class":1354},[1050,1604,1358],{"class":1331},[1050,1606,1361],{"class":1354},[1050,1608,1364],{"class":1350},[1050,1610,1367],{"class":1089},[1050,1612,1614,1617,1619,1621,1624,1626,1628,1630,1633,1637,1640,1642],{"class":1052,"line":1613},34,[1050,1615,1616],{"class":1341},"                content",[1050,1618,1318],{"class":1089},[1050,1620,1347],{"class":1189},[1050,1622,1623],{"class":1350},"'Content for load test post ",[1050,1625,1355],{"class":1354},[1050,1627,1358],{"class":1331},[1050,1629,1361],{"class":1354},[1050,1631,1632],{"class":1350},". '",[1050,1634,1636],{"class":1635},"sVsLi"," *",[1050,1638,1639],{"class":1306}," 50",[1050,1641,1101],{"class":1089},[1050,1643,1644],{"class":1265},"  # Longer content\n",[1050,1646,1648,1651,1653,1655,1657,1659,1662,1665,1668,1671,1673,1675,1677,1679],{"class":1052,"line":1647},35,[1050,1649,1650],{"class":1341},"                author",[1050,1652,1318],{"class":1089},[1050,1654,1240],{"class":1272},[1050,1656,1090],{"class":1089},[1050,1658,1279],{"class":1278},[1050,1660,1661],{"class":1089},"[",[1050,1663,1664],{"class":1278},"i ",[1050,1666,1667],{"class":1635},"%",[1050,1669,1670],{"class":1300}," len",[1050,1672,1197],{"class":1089},[1050,1674,1240],{"class":1272},[1050,1676,1090],{"class":1089},[1050,1678,1279],{"class":1278},[1050,1680,1681],{"class":1089},")],\n",[1050,1683,1685,1688,1690,1692,1694,1696],{"class":1052,"line":1684},36,[1050,1686,1687],{"class":1341},"                category",[1050,1689,1318],{"class":1089},[1050,1691,1240],{"class":1272},[1050,1693,1090],{"class":1089},[1050,1695,1480],{"class":1278},[1050,1697,1367],{"class":1089},[1050,1699,1701,1704,1706,1708,1711],{"class":1052,"line":1700},37,[1050,1702,1703],{"class":1341},"                status",[1050,1705,1318],{"class":1089},[1050,1707,1364],{"class":1401},[1050,1709,1710],{"class":1350},"published",[1050,1712,1407],{"class":1401},[1050,1714,1716],{"class":1052,"line":1715},38,[1050,1717,1413],{"class":1089},[1050,1719,1721,1723,1725,1727,1729,1731,1733,1736],{"class":1052,"line":1720},39,[1050,1722,1419],{"class":1272},[1050,1724,1090],{"class":1089},[1050,1726,1545],{"class":1278},[1050,1728,1090],{"class":1089},[1050,1730,1428],{"class":1331},[1050,1732,1197],{"class":1089},[1050,1734,1735],{"class":1331},"post",[1050,1737,1436],{"class":1089},[1050,1739,1741],{"class":1052,"line":1740},40,[1050,1742,1224],{"class":1060},[1050,1744,1746,1748,1751,1753,1755,1757,1761,1763,1766,1768,1770,1773,1775,1777,1780,1782,1786,1788,1791,1793,1795],{"class":1052,"line":1745},41,[1050,1747,1230],{"class":1189},[1050,1749,1750],{"class":1233}," make_request",[1050,1752,1197],{"class":1089},[1050,1754,1240],{"class":1239},[1050,1756,1101],{"class":1089},[1050,1758,1760],{"class":1759},"sCyAa"," url",[1050,1762,1101],{"class":1089},[1050,1764,1765],{"class":1759}," method",[1050,1767,1318],{"class":1635},[1050,1769,1364],{"class":1401},[1050,1771,1772],{"class":1350},"GET",[1050,1774,1364],{"class":1401},[1050,1776,1101],{"class":1089},[1050,1778,1779],{"class":1759}," data",[1050,1781,1318],{"class":1635},[1050,1783,1785],{"class":1784},"s8XtY","None",[1050,1787,1101],{"class":1089},[1050,1789,1790],{"class":1759}," user",[1050,1792,1318],{"class":1635},[1050,1794,1785],{"class":1784},[1050,1796,1204],{"class":1089},[1050,1798,1800,1802,1805],{"class":1052,"line":1799},42,[1050,1801,1248],{"class":1210},[1050,1803,1804],{"class":1214},"Make a single HTTP request and measure performance",[1050,1806,1218],{"class":1210},[1050,1808,1810],{"class":1052,"line":1809},43,[1050,1811,1259],{"class":1060},[1050,1813,1815,1818,1820,1823],{"class":1052,"line":1814},44,[1050,1816,1817],{"class":1060},"        client ",[1050,1819,1318],{"class":1089},[1050,1821,1822],{"class":1331}," Client",[1050,1824,1825],{"class":1089},"()\n",[1050,1827,1829],{"class":1052,"line":1828},45,[1050,1830,1259],{"class":1060},[1050,1832,1834],{"class":1052,"line":1833},46,[1050,1835,1836],{"class":1265},"        # Login if user provided\n",[1050,1838,1840,1843,1845],{"class":1052,"line":1839},47,[1050,1841,1842],{"class":1056},"        if",[1050,1844,1790],{"class":1060},[1050,1846,1847],{"class":1089},":\n",[1050,1849,1851,1854,1856,1859,1861,1863],{"class":1052,"line":1850},48,[1050,1852,1853],{"class":1060},"            client",[1050,1855,1090],{"class":1089},[1050,1857,1858],{"class":1331},"force_login",[1050,1860,1197],{"class":1089},[1050,1862,1433],{"class":1331},[1050,1864,1436],{"class":1089},[1050,1866,1868],{"class":1052,"line":1867},49,[1050,1869,1259],{"class":1060},[1050,1871,1873,1876,1878,1881,1883,1886],{"class":1052,"line":1872},50,[1050,1874,1875],{"class":1060},"        start_time ",[1050,1877,1318],{"class":1089},[1050,1879,1880],{"class":1060}," time",[1050,1882,1090],{"class":1089},[1050,1884,1885],{"class":1331},"time",[1050,1887,1825],{"class":1089},[1050,1889,1891],{"class":1052,"line":1890},51,[1050,1892,1259],{"class":1060},[1050,1894,1896,1899],{"class":1052,"line":1895},52,[1050,1897,1898],{"class":1056},"        try",[1050,1900,1847],{"class":1089},[1050,1902,1904,1907,1910,1913,1916,1918,1920],{"class":1052,"line":1903},53,[1050,1905,1906],{"class":1056},"            if",[1050,1908,1909],{"class":1060}," method ",[1050,1911,1912],{"class":1635},"==",[1050,1914,1915],{"class":1401}," '",[1050,1917,1772],{"class":1350},[1050,1919,1364],{"class":1401},[1050,1921,1847],{"class":1089},[1050,1923,1925,1928,1930,1933,1935,1938,1940,1943],{"class":1052,"line":1924},54,[1050,1926,1927],{"class":1060},"                response ",[1050,1929,1318],{"class":1089},[1050,1931,1932],{"class":1060}," client",[1050,1934,1090],{"class":1089},[1050,1936,1937],{"class":1331},"get",[1050,1939,1197],{"class":1089},[1050,1941,1942],{"class":1331},"url",[1050,1944,1436],{"class":1089},[1050,1946,1948,1951,1953,1955,1957,1960,1962],{"class":1052,"line":1947},55,[1050,1949,1950],{"class":1056},"            elif",[1050,1952,1909],{"class":1060},[1050,1954,1912],{"class":1635},[1050,1956,1915],{"class":1401},[1050,1958,1959],{"class":1350},"POST",[1050,1961,1364],{"class":1401},[1050,1963,1847],{"class":1089},[1050,1965,1967,1969,1971,1973,1975,1977,1979,1981,1983,1986,1989],{"class":1052,"line":1966},56,[1050,1968,1927],{"class":1060},[1050,1970,1318],{"class":1089},[1050,1972,1932],{"class":1060},[1050,1974,1090],{"class":1089},[1050,1976,1735],{"class":1331},[1050,1978,1197],{"class":1089},[1050,1980,1942],{"class":1331},[1050,1982,1101],{"class":1089},[1050,1984,1985],{"class":1331}," data ",[1050,1987,1988],{"class":1056},"or",[1050,1990,1991],{"class":1089}," {})\n",[1050,1993,1995,1998],{"class":1052,"line":1994},57,[1050,1996,1997],{"class":1056},"            else",[1050,1999,1847],{"class":1089},[1050,2001,2003,2006,2010,2012,2014,2017,2019,2022,2024,2027],{"class":1052,"line":2002},58,[1050,2004,2005],{"class":1056},"                raise",[1050,2007,2009],{"class":2008},"sa2tF"," ValueError",[1050,2011,1197],{"class":1089},[1050,2013,1347],{"class":1189},[1050,2015,2016],{"class":1350},"\"Unsupported method: ",[1050,2018,1355],{"class":1354},[1050,2020,2021],{"class":1331},"method",[1050,2023,1361],{"class":1354},[1050,2025,2026],{"class":1350},"\"",[1050,2028,1436],{"class":1089},[1050,2030,2032],{"class":1052,"line":2031},59,[1050,2033,2034],{"class":1060},"            \n",[1050,2036,2038,2041,2043,2045,2047,2049],{"class":1052,"line":2037},60,[1050,2039,2040],{"class":1060},"            end_time ",[1050,2042,1318],{"class":1089},[1050,2044,1880],{"class":1060},[1050,2046,1090],{"class":1089},[1050,2048,1885],{"class":1331},[1050,2050,1825],{"class":1089},[1050,2052,2054],{"class":1052,"line":2053},61,[1050,2055,2034],{"class":1060},[1050,2057,2059,2062],{"class":1052,"line":2058},62,[1050,2060,2061],{"class":1056},"            return",[1050,2063,2064],{"class":1089}," {\n",[1050,2066,2068,2071,2074,2076,2079,2082,2084,2086],{"class":1052,"line":2067},63,[1050,2069,2070],{"class":1401},"                '",[1050,2072,2073],{"class":1350},"status_code",[1050,2075,1364],{"class":1401},[1050,2077,2078],{"class":1089},":",[1050,2080,2081],{"class":1060}," response",[1050,2083,1090],{"class":1089},[1050,2085,2073],{"class":1278},[1050,2087,1367],{"class":1089},[1050,2089,2091,2093,2096,2098,2100,2103,2106,2109],{"class":1052,"line":2090},64,[1050,2092,2070],{"class":1401},[1050,2094,2095],{"class":1350},"response_time",[1050,2097,1364],{"class":1401},[1050,2099,2078],{"class":1089},[1050,2101,2102],{"class":1060}," end_time ",[1050,2104,2105],{"class":1635},"-",[1050,2107,2108],{"class":1060}," start_time",[1050,2110,1367],{"class":1089},[1050,2112,2114,2116,2119,2121,2123,2126,2129,2131,2133,2135,2138,2141],{"class":1052,"line":2113},65,[1050,2115,2070],{"class":1401},[1050,2117,2118],{"class":1350},"success",[1050,2120,1364],{"class":1401},[1050,2122,2078],{"class":1089},[1050,2124,2125],{"class":1306}," 200",[1050,2127,2128],{"class":1635}," \u003C=",[1050,2130,2081],{"class":1060},[1050,2132,1090],{"class":1089},[1050,2134,2073],{"class":1278},[1050,2136,2137],{"class":1635}," \u003C",[1050,2139,2140],{"class":1306}," 400",[1050,2142,1367],{"class":1089},[1050,2144,2146,2148,2151,2153,2155,2157,2159,2162,2164,2167],{"class":1052,"line":2145},66,[1050,2147,2070],{"class":1401},[1050,2149,2150],{"class":1350},"content_length",[1050,2152,1364],{"class":1401},[1050,2154,2078],{"class":1089},[1050,2156,1670],{"class":1300},[1050,2158,1197],{"class":1089},[1050,2160,2161],{"class":1331},"response",[1050,2163,1090],{"class":1089},[1050,2165,2166],{"class":1278},"content",[1050,2168,2169],{"class":1089},"),\n",[1050,2171,2173,2175,2178,2180,2182],{"class":1052,"line":2172},67,[1050,2174,2070],{"class":1401},[1050,2176,2177],{"class":1350},"error",[1050,2179,1364],{"class":1401},[1050,2181,2078],{"class":1089},[1050,2183,2184],{"class":1784}," None\n",[1050,2186,2188],{"class":1052,"line":2187},68,[1050,2189,2190],{"class":1089},"            }\n",[1050,2192,2194],{"class":1052,"line":2193},69,[1050,2195,2034],{"class":1060},[1050,2197,2199,2202,2205,2208,2211],{"class":1052,"line":2198},70,[1050,2200,2201],{"class":1056},"        except",[1050,2203,2204],{"class":2008}," Exception",[1050,2206,2207],{"class":1056}," as",[1050,2209,2210],{"class":1060}," e",[1050,2212,1847],{"class":1089},[1050,2214,2216,2218,2220,2222,2224,2226],{"class":1052,"line":2215},71,[1050,2217,2040],{"class":1060},[1050,2219,1318],{"class":1089},[1050,2221,1880],{"class":1060},[1050,2223,1090],{"class":1089},[1050,2225,1885],{"class":1331},[1050,2227,1825],{"class":1089},[1050,2229,2231,2233],{"class":1052,"line":2230},72,[1050,2232,2061],{"class":1056},[1050,2234,2064],{"class":1089},[1050,2236,2238,2240,2242,2244,2246,2249],{"class":1052,"line":2237},73,[1050,2239,2070],{"class":1401},[1050,2241,2073],{"class":1350},[1050,2243,1364],{"class":1401},[1050,2245,2078],{"class":1089},[1050,2247,2248],{"class":1306}," 500",[1050,2250,1367],{"class":1089},[1050,2252,2254,2256,2258,2260,2262,2264,2266,2268],{"class":1052,"line":2253},74,[1050,2255,2070],{"class":1401},[1050,2257,2095],{"class":1350},[1050,2259,1364],{"class":1401},[1050,2261,2078],{"class":1089},[1050,2263,2102],{"class":1060},[1050,2265,2105],{"class":1635},[1050,2267,2108],{"class":1060},[1050,2269,1367],{"class":1089},[1050,2271,2273,2275,2277,2279,2281,2284],{"class":1052,"line":2272},75,[1050,2274,2070],{"class":1401},[1050,2276,2118],{"class":1350},[1050,2278,1364],{"class":1401},[1050,2280,2078],{"class":1089},[1050,2282,2283],{"class":1784}," False",[1050,2285,1367],{"class":1089},[1050,2287,2289,2291,2293,2295,2297,2300],{"class":1052,"line":2288},76,[1050,2290,2070],{"class":1401},[1050,2292,2150],{"class":1350},[1050,2294,1364],{"class":1401},[1050,2296,2078],{"class":1089},[1050,2298,2299],{"class":1306}," 0",[1050,2301,1367],{"class":1089},[1050,2303,2305,2307,2309,2311,2313,2316,2318,2321],{"class":1052,"line":2304},77,[1050,2306,2070],{"class":1401},[1050,2308,2177],{"class":1350},[1050,2310,1364],{"class":1401},[1050,2312,2078],{"class":1089},[1050,2314,2315],{"class":2008}," str",[1050,2317,1197],{"class":1089},[1050,2319,2320],{"class":1331},"e",[1050,2322,1436],{"class":1089},[1050,2324,2326],{"class":1052,"line":2325},78,[1050,2327,2190],{"class":1089},[1050,2329,2331],{"class":1052,"line":2330},79,[1050,2332,1224],{"class":1060},[1050,2334,2336,2338,2341,2343,2345,2347,2349,2351,2354,2356,2358,2360,2363,2365,2367,2369],{"class":1052,"line":2335},80,[1050,2337,1230],{"class":1189},[1050,2339,2340],{"class":1233}," run_load_test",[1050,2342,1197],{"class":1089},[1050,2344,1240],{"class":1239},[1050,2346,1101],{"class":1089},[1050,2348,1760],{"class":1759},[1050,2350,1101],{"class":1089},[1050,2352,2353],{"class":1759}," num_requests",[1050,2355,1318],{"class":1635},[1050,2357,1565],{"class":1306},[1050,2359,1101],{"class":1089},[1050,2361,2362],{"class":1759}," concurrent_users",[1050,2364,1318],{"class":1635},[1050,2366,1307],{"class":1306},[1050,2368,1101],{"class":1089},[1050,2370,2371],{"class":1060}," \n",[1050,2373,2375,2378,2380,2382,2384,2386,2388,2390,2392,2394,2396,2399,2401,2404],{"class":1052,"line":2374},81,[1050,2376,2377],{"class":1759},"                      method",[1050,2379,1318],{"class":1635},[1050,2381,1364],{"class":1401},[1050,2383,1772],{"class":1350},[1050,2385,1364],{"class":1401},[1050,2387,1101],{"class":1089},[1050,2389,1779],{"class":1759},[1050,2391,1318],{"class":1635},[1050,2393,1785],{"class":1784},[1050,2395,1101],{"class":1089},[1050,2397,2398],{"class":1759}," authenticated",[1050,2400,1318],{"class":1635},[1050,2402,2403],{"class":1784},"False",[1050,2405,1204],{"class":1089},[1050,2407,2409,2411,2414],{"class":1052,"line":2408},82,[1050,2410,1248],{"class":1210},[1050,2412,2413],{"class":1214},"Run load test with specified parameters",[1050,2415,1218],{"class":1210},[1050,2417,2419],{"class":1052,"line":2418},83,[1050,2420,1259],{"class":1060},[1050,2422,2424,2427,2429],{"class":1052,"line":2423},84,[1050,2425,2426],{"class":1060},"        results ",[1050,2428,1318],{"class":1089},[1050,2430,1285],{"class":1089},[1050,2432,2434],{"class":1052,"line":2433},85,[1050,2435,1259],{"class":1060},[1050,2437,2439,2442,2445],{"class":1052,"line":2438},86,[1050,2440,2441],{"class":1189},"        def",[1050,2443,2444],{"class":1233}," worker",[1050,2446,2447],{"class":1089},"():\n",[1050,2449,2451,2454,2457],{"class":1052,"line":2450},87,[1050,2452,2453],{"class":1210},"            \"\"\"",[1050,2455,2456],{"class":1214},"Worker function for each thread",[1050,2458,1218],{"class":1210},[1050,2460,2462,2464,2466],{"class":1052,"line":2461},88,[1050,2463,1315],{"class":1060},[1050,2465,1318],{"class":1089},[1050,2467,2184],{"class":1784},[1050,2469,2471,2473,2476,2479,2482,2484,2486],{"class":1052,"line":2470},89,[1050,2472,1906],{"class":1056},[1050,2474,2475],{"class":1060}," authenticated ",[1050,2477,2478],{"class":1635},"and",[1050,2480,2481],{"class":1272}," self",[1050,2483,1090],{"class":1089},[1050,2485,1279],{"class":1278},[1050,2487,1847],{"class":1089},[1050,2489,2491],{"class":1052,"line":2490},90,[1050,2492,2493],{"class":1265},"                # Assign user in round-robin fashion\n",[1050,2495,2497,2500,2502,2505,2507,2510,2513,2516,2519,2521,2523,2525,2527,2529],{"class":1052,"line":2496},91,[1050,2498,2499],{"class":1060},"                user_index ",[1050,2501,1318],{"class":1089},[1050,2503,2504],{"class":1060}," threading",[1050,2506,1090],{"class":1089},[1050,2508,2509],{"class":1331},"current_thread",[1050,2511,2512],{"class":1089},"().",[1050,2514,2515],{"class":1278},"ident",[1050,2517,2518],{"class":1635}," %",[1050,2520,1670],{"class":1300},[1050,2522,1197],{"class":1089},[1050,2524,1240],{"class":1272},[1050,2526,1090],{"class":1089},[1050,2528,1279],{"class":1278},[1050,2530,1436],{"class":1089},[1050,2532,2534,2537,2539,2541,2543,2545,2547,2550],{"class":1052,"line":2533},92,[1050,2535,2536],{"class":1060},"                user ",[1050,2538,1318],{"class":1089},[1050,2540,2481],{"class":1272},[1050,2542,1090],{"class":1089},[1050,2544,1279],{"class":1278},[1050,2546,1661],{"class":1089},[1050,2548,2549],{"class":1278},"user_index",[1050,2551,2552],{"class":1089},"]\n",[1050,2554,2556],{"class":1052,"line":2555},93,[1050,2557,2034],{"class":1060},[1050,2559,2561,2563,2565,2567,2570,2572,2574,2576,2578,2580,2582,2584,2586],{"class":1052,"line":2560},94,[1050,2562,2061],{"class":1056},[1050,2564,2481],{"class":1272},[1050,2566,1090],{"class":1089},[1050,2568,2569],{"class":1331},"make_request",[1050,2571,1197],{"class":1089},[1050,2573,1942],{"class":1331},[1050,2575,1101],{"class":1089},[1050,2577,1765],{"class":1331},[1050,2579,1101],{"class":1089},[1050,2581,1779],{"class":1331},[1050,2583,1101],{"class":1089},[1050,2585,1790],{"class":1331},[1050,2587,1436],{"class":1089},[1050,2589,2591],{"class":1052,"line":2590},95,[1050,2592,1259],{"class":1060},[1050,2594,2596],{"class":1052,"line":2595},96,[1050,2597,2598],{"class":1265},"        # Execute concurrent requests\n",[1050,2600,2602,2605,2607,2609,2612,2614,2617,2620,2622,2625],{"class":1052,"line":2601},97,[1050,2603,2604],{"class":1056},"        with",[1050,2606,1098],{"class":1331},[1050,2608,1197],{"class":1089},[1050,2610,2611],{"class":1341},"max_workers",[1050,2613,1318],{"class":1089},[1050,2615,2616],{"class":1331},"concurrent_users",[1050,2618,2619],{"class":1089},")",[1050,2621,2207],{"class":1056},[1050,2623,2624],{"class":1060}," executor",[1050,2626,1847],{"class":1089},[1050,2628,2630],{"class":1052,"line":2629},98,[1050,2631,2632],{"class":1265},"            # Submit all requests\n",[1050,2634,2636,2639,2641,2644,2647,2649,2652,2654,2657,2659,2662,2665,2667,2669,2671,2674],{"class":1052,"line":2635},99,[1050,2637,2638],{"class":1060},"            futures ",[1050,2640,1318],{"class":1089},[1050,2642,2643],{"class":1089}," [",[1050,2645,2646],{"class":1060},"executor",[1050,2648,1090],{"class":1089},[1050,2650,2651],{"class":1331},"submit",[1050,2653,1197],{"class":1089},[1050,2655,2656],{"class":1331},"worker",[1050,2658,2619],{"class":1089},[1050,2660,2661],{"class":1056}," for",[1050,2663,2664],{"class":1060}," _ ",[1050,2666,1297],{"class":1056},[1050,2668,1301],{"class":1300},[1050,2670,1197],{"class":1089},[1050,2672,2673],{"class":1331},"num_requests",[1050,2675,2676],{"class":1089},")]\n",[1050,2678,2680],{"class":1052,"line":2679},100,[1050,2681,2034],{"class":1060},[1050,2683,2685],{"class":1052,"line":2684},101,[1050,2686,2687],{"class":1265},"            # Collect results\n",[1050,2689,2691,2694,2697,2699,2702,2704,2707],{"class":1052,"line":2690},102,[1050,2692,2693],{"class":1056},"            for",[1050,2695,2696],{"class":1060}," future ",[1050,2698,1297],{"class":1056},[1050,2700,2701],{"class":1331}," as_completed",[1050,2703,1197],{"class":1089},[1050,2705,2706],{"class":1331},"futures",[1050,2708,1204],{"class":1089},[1050,2710,2712,2715],{"class":1052,"line":2711},103,[1050,2713,2714],{"class":1056},"                try",[1050,2716,1847],{"class":1089},[1050,2718,2720,2723,2725,2728,2730,2733,2735,2738,2740,2743,2745],{"class":1052,"line":2719},104,[1050,2721,2722],{"class":1060},"                    result ",[1050,2724,1318],{"class":1089},[1050,2726,2727],{"class":1060}," future",[1050,2729,1090],{"class":1089},[1050,2731,2732],{"class":1331},"result",[1050,2734,1197],{"class":1089},[1050,2736,2737],{"class":1341},"timeout",[1050,2739,1318],{"class":1089},[1050,2741,2742],{"class":1306},"30",[1050,2744,2619],{"class":1089},[1050,2746,2747],{"class":1265},"  # 30 second timeout\n",[1050,2749,2751,2754,2756,2758,2760,2762],{"class":1052,"line":2750},105,[1050,2752,2753],{"class":1060},"                    results",[1050,2755,1090],{"class":1089},[1050,2757,1428],{"class":1331},[1050,2759,1197],{"class":1089},[1050,2761,2732],{"class":1331},[1050,2763,1436],{"class":1089},[1050,2765,2767,2770,2772,2774,2776],{"class":1052,"line":2766},106,[1050,2768,2769],{"class":1056},"                except",[1050,2771,2204],{"class":2008},[1050,2773,2207],{"class":1056},[1050,2775,2210],{"class":1060},[1050,2777,1847],{"class":1089},[1050,2779,2781,2783,2785,2787],{"class":1052,"line":2780},107,[1050,2782,2753],{"class":1060},[1050,2784,1090],{"class":1089},[1050,2786,1428],{"class":1331},[1050,2788,2789],{"class":1089},"({\n",[1050,2791,2793,2796,2798,2800,2802,2804],{"class":1052,"line":2792},108,[1050,2794,2795],{"class":1401},"                        '",[1050,2797,2073],{"class":1350},[1050,2799,1364],{"class":1401},[1050,2801,2078],{"class":1089},[1050,2803,2248],{"class":1306},[1050,2805,1367],{"class":1089},[1050,2807,2809,2811,2813,2815,2817,2820],{"class":1052,"line":2808},109,[1050,2810,2795],{"class":1401},[1050,2812,2095],{"class":1350},[1050,2814,1364],{"class":1401},[1050,2816,2078],{"class":1089},[1050,2818,2819],{"class":1306}," 30.0",[1050,2821,1367],{"class":1089},[1050,2823,2825,2827,2829,2831,2833,2835],{"class":1052,"line":2824},110,[1050,2826,2795],{"class":1401},[1050,2828,2118],{"class":1350},[1050,2830,1364],{"class":1401},[1050,2832,2078],{"class":1089},[1050,2834,2283],{"class":1784},[1050,2836,1367],{"class":1089},[1050,2838,2840,2842,2844,2846,2848,2850],{"class":1052,"line":2839},111,[1050,2841,2795],{"class":1401},[1050,2843,2150],{"class":1350},[1050,2845,1364],{"class":1401},[1050,2847,2078],{"class":1089},[1050,2849,2299],{"class":1306},[1050,2851,1367],{"class":1089},[1050,2853,2855,2857,2859,2861,2863,2866,2869,2871,2873,2875],{"class":1052,"line":2854},112,[1050,2856,2795],{"class":1401},[1050,2858,2177],{"class":1350},[1050,2860,1364],{"class":1401},[1050,2862,2078],{"class":1089},[1050,2864,2865],{"class":1189}," f",[1050,2867,2868],{"class":1350},"\"Request timeout or error: ",[1050,2870,1355],{"class":1354},[1050,2872,2320],{"class":1331},[1050,2874,1361],{"class":1354},[1050,2876,2877],{"class":1350},"\"\n",[1050,2879,2881],{"class":1052,"line":2880},113,[1050,2882,2883],{"class":1089},"                    })\n",[1050,2885,2887],{"class":1052,"line":2886},114,[1050,2888,1259],{"class":1060},[1050,2890,2892,2895,2897,2899,2902,2904,2907],{"class":1052,"line":2891},115,[1050,2893,2894],{"class":1056},"        return",[1050,2896,2481],{"class":1272},[1050,2898,1090],{"class":1089},[1050,2900,2901],{"class":1331},"analyze_results",[1050,2903,1197],{"class":1089},[1050,2905,2906],{"class":1331},"results",[1050,2908,1436],{"class":1089},[1050,2910,2912],{"class":1052,"line":2911},116,[1050,2913,1224],{"class":1060},[1050,2915,2917,2919,2922,2924,2926,2928,2931],{"class":1052,"line":2916},117,[1050,2918,1230],{"class":1189},[1050,2920,2921],{"class":1233}," analyze_results",[1050,2923,1197],{"class":1089},[1050,2925,1240],{"class":1239},[1050,2927,1101],{"class":1089},[1050,2929,2930],{"class":1759}," results",[1050,2932,1204],{"class":1089},[1050,2934,2936,2938,2941],{"class":1052,"line":2935},118,[1050,2937,1248],{"class":1210},[1050,2939,2940],{"class":1214},"Analyze load test results",[1050,2942,1218],{"class":1210},[1050,2944,2946],{"class":1052,"line":2945},119,[1050,2947,1259],{"class":1060},[1050,2949,2951,2953,2956,2958],{"class":1052,"line":2950},120,[1050,2952,1842],{"class":1056},[1050,2954,2955],{"class":1635}," not",[1050,2957,2930],{"class":1060},[1050,2959,1847],{"class":1089},[1050,2961,2963,2965,2968,2970,2972,2974,2976,2978,2981,2983],{"class":1052,"line":2962},121,[1050,2964,2061],{"class":1056},[1050,2966,2967],{"class":1089}," {",[1050,2969,1364],{"class":1401},[1050,2971,2177],{"class":1350},[1050,2973,1364],{"class":1401},[1050,2975,2078],{"class":1089},[1050,2977,1915],{"class":1401},[1050,2979,2980],{"class":1350},"No results to analyze",[1050,2982,1364],{"class":1401},[1050,2984,2985],{"class":1089},"}\n",[1050,2987,2989],{"class":1052,"line":2988},122,[1050,2990,1259],{"class":1060},[1050,2992,2994],{"class":1052,"line":2993},123,[1050,2995,2996],{"class":1265},"        # Extract metrics\n",[1050,2998,3000,3003,3005,3007,3010,3012,3014,3016,3018,3021,3023,3026,3028,3030],{"class":1052,"line":2999},124,[1050,3001,3002],{"class":1060},"        response_times ",[1050,3004,1318],{"class":1089},[1050,3006,2643],{"class":1089},[1050,3008,3009],{"class":1060},"r",[1050,3011,1661],{"class":1089},[1050,3013,1364],{"class":1401},[1050,3015,2095],{"class":1350},[1050,3017,1364],{"class":1401},[1050,3019,3020],{"class":1089},"]",[1050,3022,2661],{"class":1056},[1050,3024,3025],{"class":1060}," r ",[1050,3027,1297],{"class":1056},[1050,3029,2930],{"class":1060},[1050,3031,2552],{"class":1089},[1050,3033,3035,3038,3040,3042,3045,3048,3050,3052,3055,3058,3061,3063,3065,3067,3069],{"class":1052,"line":3034},125,[1050,3036,3037],{"class":1060},"        successful_requests ",[1050,3039,1318],{"class":1089},[1050,3041,2643],{"class":1089},[1050,3043,3044],{"class":1060},"r ",[1050,3046,3047],{"class":1056},"for",[1050,3049,3025],{"class":1060},[1050,3051,1297],{"class":1056},[1050,3053,3054],{"class":1060}," results ",[1050,3056,3057],{"class":1056},"if",[1050,3059,3060],{"class":1060}," r",[1050,3062,1661],{"class":1089},[1050,3064,1364],{"class":1401},[1050,3066,2118],{"class":1350},[1050,3068,1364],{"class":1401},[1050,3070,3071],{"class":1089},"]]\n",[1050,3073,3075,3078,3080,3082,3084,3086,3088,3090,3092,3094,3096,3098,3100,3102,3104,3106],{"class":1052,"line":3074},126,[1050,3076,3077],{"class":1060},"        failed_requests ",[1050,3079,1318],{"class":1089},[1050,3081,2643],{"class":1089},[1050,3083,3044],{"class":1060},[1050,3085,3047],{"class":1056},[1050,3087,3025],{"class":1060},[1050,3089,1297],{"class":1056},[1050,3091,3054],{"class":1060},[1050,3093,3057],{"class":1056},[1050,3095,2955],{"class":1635},[1050,3097,3060],{"class":1060},[1050,3099,1661],{"class":1089},[1050,3101,1364],{"class":1401},[1050,3103,2118],{"class":1350},[1050,3105,1364],{"class":1401},[1050,3107,3071],{"class":1089},[1050,3109,3111],{"class":1052,"line":3110},127,[1050,3112,1259],{"class":1060},[1050,3114,3116],{"class":1052,"line":3115},128,[1050,3117,3118],{"class":1265},"        # Calculate statistics\n",[1050,3120,3122,3125,3127],{"class":1052,"line":3121},129,[1050,3123,3124],{"class":1060},"        analysis ",[1050,3126,1318],{"class":1089},[1050,3128,2064],{"class":1089},[1050,3130,3132,3135,3138,3140,3142,3144,3146,3148],{"class":1052,"line":3131},130,[1050,3133,3134],{"class":1401},"            '",[1050,3136,3137],{"class":1350},"total_requests",[1050,3139,1364],{"class":1401},[1050,3141,2078],{"class":1089},[1050,3143,1670],{"class":1300},[1050,3145,1197],{"class":1089},[1050,3147,2906],{"class":1331},[1050,3149,2169],{"class":1089},[1050,3151,3153,3155,3158,3160,3162,3164,3166,3168],{"class":1052,"line":3152},131,[1050,3154,3134],{"class":1401},[1050,3156,3157],{"class":1350},"successful_requests",[1050,3159,1364],{"class":1401},[1050,3161,2078],{"class":1089},[1050,3163,1670],{"class":1300},[1050,3165,1197],{"class":1089},[1050,3167,3157],{"class":1331},[1050,3169,2169],{"class":1089},[1050,3171,3173,3175,3178,3180,3182,3184,3186,3188],{"class":1052,"line":3172},132,[1050,3174,3134],{"class":1401},[1050,3176,3177],{"class":1350},"failed_requests",[1050,3179,1364],{"class":1401},[1050,3181,2078],{"class":1089},[1050,3183,1670],{"class":1300},[1050,3185,1197],{"class":1089},[1050,3187,3177],{"class":1331},[1050,3189,2169],{"class":1089},[1050,3191,3193,3195,3198,3200,3202,3204,3206,3208,3210,3213,3215,3217,3219,3221,3223,3226],{"class":1052,"line":3192},133,[1050,3194,3134],{"class":1401},[1050,3196,3197],{"class":1350},"success_rate",[1050,3199,1364],{"class":1401},[1050,3201,2078],{"class":1089},[1050,3203,1670],{"class":1300},[1050,3205,1197],{"class":1089},[1050,3207,3157],{"class":1331},[1050,3209,2619],{"class":1089},[1050,3211,3212],{"class":1635}," /",[1050,3214,1670],{"class":1300},[1050,3216,1197],{"class":1089},[1050,3218,2906],{"class":1331},[1050,3220,2619],{"class":1089},[1050,3222,1636],{"class":1635},[1050,3224,3225],{"class":1306}," 100",[1050,3227,1367],{"class":1089},[1050,3229,3231],{"class":1052,"line":3230},134,[1050,3232,2034],{"class":1060},[1050,3234,3236],{"class":1052,"line":3235},135,[1050,3237,3238],{"class":1265},"            # Response time statistics\n",[1050,3240,3242,3244,3247,3249,3251,3254,3256,3259,3261,3264],{"class":1052,"line":3241},136,[1050,3243,3134],{"class":1401},[1050,3245,3246],{"class":1350},"avg_response_time",[1050,3248,1364],{"class":1401},[1050,3250,2078],{"class":1089},[1050,3252,3253],{"class":1060}," statistics",[1050,3255,1090],{"class":1089},[1050,3257,3258],{"class":1331},"mean",[1050,3260,1197],{"class":1089},[1050,3262,3263],{"class":1331},"response_times",[1050,3265,2169],{"class":1089},[1050,3267,3269,3271,3274,3276,3278,3281,3283,3285],{"class":1052,"line":3268},137,[1050,3270,3134],{"class":1401},[1050,3272,3273],{"class":1350},"min_response_time",[1050,3275,1364],{"class":1401},[1050,3277,2078],{"class":1089},[1050,3279,3280],{"class":1300}," min",[1050,3282,1197],{"class":1089},[1050,3284,3263],{"class":1331},[1050,3286,2169],{"class":1089},[1050,3288,3290,3292,3295,3297,3299,3302,3304,3306],{"class":1052,"line":3289},138,[1050,3291,3134],{"class":1401},[1050,3293,3294],{"class":1350},"max_response_time",[1050,3296,1364],{"class":1401},[1050,3298,2078],{"class":1089},[1050,3300,3301],{"class":1300}," max",[1050,3303,1197],{"class":1089},[1050,3305,3263],{"class":1331},[1050,3307,2169],{"class":1089},[1050,3309,3311,3313,3316,3318,3320,3322,3324,3327,3329,3331],{"class":1052,"line":3310},139,[1050,3312,3134],{"class":1401},[1050,3314,3315],{"class":1350},"median_response_time",[1050,3317,1364],{"class":1401},[1050,3319,2078],{"class":1089},[1050,3321,3253],{"class":1060},[1050,3323,1090],{"class":1089},[1050,3325,3326],{"class":1331},"median",[1050,3328,1197],{"class":1089},[1050,3330,3263],{"class":1331},[1050,3332,2169],{"class":1089},[1050,3334,3336],{"class":1052,"line":3335},140,[1050,3337,2034],{"class":1060},[1050,3339,3341],{"class":1052,"line":3340},141,[1050,3342,3343],{"class":1265},"            # Percentiles\n",[1050,3345,3347,3349,3352,3354,3356,3358,3360,3363,3365,3367,3369,3372],{"class":1052,"line":3346},142,[1050,3348,3134],{"class":1401},[1050,3350,3351],{"class":1350},"p95_response_time",[1050,3353,1364],{"class":1401},[1050,3355,2078],{"class":1089},[1050,3357,2481],{"class":1272},[1050,3359,1090],{"class":1089},[1050,3361,3362],{"class":1331},"percentile",[1050,3364,1197],{"class":1089},[1050,3366,3263],{"class":1331},[1050,3368,1101],{"class":1089},[1050,3370,3371],{"class":1306}," 95",[1050,3373,2169],{"class":1089},[1050,3375,3377,3379,3382,3384,3386,3388,3390,3392,3394,3396,3398,3401],{"class":1052,"line":3376},143,[1050,3378,3134],{"class":1401},[1050,3380,3381],{"class":1350},"p99_response_time",[1050,3383,1364],{"class":1401},[1050,3385,2078],{"class":1089},[1050,3387,2481],{"class":1272},[1050,3389,1090],{"class":1089},[1050,3391,3362],{"class":1331},[1050,3393,1197],{"class":1089},[1050,3395,3263],{"class":1331},[1050,3397,1101],{"class":1089},[1050,3399,3400],{"class":1306}," 99",[1050,3402,2169],{"class":1089},[1050,3404,3406],{"class":1052,"line":3405},144,[1050,3407,2034],{"class":1060},[1050,3409,3411],{"class":1052,"line":3410},145,[1050,3412,3413],{"class":1265},"            # Throughput\n",[1050,3415,3417,3419,3422,3424,3426,3428,3430,3432,3434,3436,3439,3441,3443,3445,3447,3449,3451,3453],{"class":1052,"line":3416},146,[1050,3418,3134],{"class":1401},[1050,3420,3421],{"class":1350},"requests_per_second",[1050,3423,1364],{"class":1401},[1050,3425,2078],{"class":1089},[1050,3427,1670],{"class":1300},[1050,3429,1197],{"class":1089},[1050,3431,2906],{"class":1331},[1050,3433,2619],{"class":1089},[1050,3435,3212],{"class":1635},[1050,3437,3438],{"class":1300}," sum",[1050,3440,1197],{"class":1089},[1050,3442,3263],{"class":1331},[1050,3444,2619],{"class":1089},[1050,3446,1636],{"class":1635},[1050,3448,1670],{"class":1300},[1050,3450,1197],{"class":1089},[1050,3452,2906],{"class":1331},[1050,3454,2169],{"class":1089},[1050,3456,3458],{"class":1052,"line":3457},147,[1050,3459,2034],{"class":1060},[1050,3461,3463],{"class":1052,"line":3462},148,[1050,3464,3465],{"class":1265},"            # Error analysis\n",[1050,3467,3469,3471,3474,3476,3478,3480,3482,3484,3486,3488,3490,3492,3494,3496,3498,3501,3503,3505,3507,3509,3511,3513],{"class":1052,"line":3468},149,[1050,3470,3134],{"class":1401},[1050,3472,3473],{"class":1350},"errors",[1050,3475,1364],{"class":1401},[1050,3477,2078],{"class":1089},[1050,3479,2643],{"class":1089},[1050,3481,3009],{"class":1060},[1050,3483,1661],{"class":1089},[1050,3485,1364],{"class":1401},[1050,3487,2177],{"class":1350},[1050,3489,1364],{"class":1401},[1050,3491,3020],{"class":1089},[1050,3493,2661],{"class":1056},[1050,3495,3025],{"class":1060},[1050,3497,1297],{"class":1056},[1050,3499,3500],{"class":1060}," failed_requests ",[1050,3502,3057],{"class":1056},[1050,3504,3060],{"class":1060},[1050,3506,1661],{"class":1089},[1050,3508,1364],{"class":1401},[1050,3510,2177],{"class":1350},[1050,3512,1364],{"class":1401},[1050,3514,3515],{"class":1089},"]],\n",[1050,3517,3519,3521,3524,3526,3528,3530,3532,3535,3537,3539],{"class":1052,"line":3518},150,[1050,3520,3134],{"class":1401},[1050,3522,3523],{"class":1350},"status_codes",[1050,3525,1364],{"class":1401},[1050,3527,2078],{"class":1089},[1050,3529,2481],{"class":1272},[1050,3531,1090],{"class":1089},[1050,3533,3534],{"class":1331},"count_status_codes",[1050,3536,1197],{"class":1089},[1050,3538,2906],{"class":1331},[1050,3540,1436],{"class":1089},[1050,3542,3544],{"class":1052,"line":3543},151,[1050,3545,3546],{"class":1089},"        }\n",[1050,3548,3550],{"class":1052,"line":3549},152,[1050,3551,1259],{"class":1060},[1050,3553,3555,3557],{"class":1052,"line":3554},153,[1050,3556,2894],{"class":1056},[1050,3558,3559],{"class":1060}," analysis\n",[1050,3561,3563],{"class":1052,"line":3562},154,[1050,3564,1224],{"class":1060},[1050,3566,3568,3570,3573,3575,3577,3579,3581,3583,3585],{"class":1052,"line":3567},155,[1050,3569,1230],{"class":1189},[1050,3571,3572],{"class":1233}," percentile",[1050,3574,1197],{"class":1089},[1050,3576,1240],{"class":1239},[1050,3578,1101],{"class":1089},[1050,3580,1779],{"class":1759},[1050,3582,1101],{"class":1089},[1050,3584,3572],{"class":1759},[1050,3586,1204],{"class":1089},[1050,3588,3590,3592,3595],{"class":1052,"line":3589},156,[1050,3591,1248],{"class":1210},[1050,3593,3594],{"class":1214},"Calculate percentile of data",[1050,3596,1218],{"class":1210},[1050,3598,3600,3603,3605,3608,3610,3613],{"class":1052,"line":3599},157,[1050,3601,3602],{"class":1060},"        sorted_data ",[1050,3604,1318],{"class":1089},[1050,3606,3607],{"class":1300}," sorted",[1050,3609,1197],{"class":1089},[1050,3611,3612],{"class":1331},"data",[1050,3614,1436],{"class":1089},[1050,3616,3618,3621,3623,3626,3628,3631,3633,3636,3638,3640,3643,3646,3648],{"class":1052,"line":3617},158,[1050,3619,3620],{"class":1060},"        index ",[1050,3622,1318],{"class":1089},[1050,3624,3625],{"class":2008}," int",[1050,3627,1197],{"class":1089},[1050,3629,3630],{"class":1300},"len",[1050,3632,1197],{"class":1089},[1050,3634,3635],{"class":1331},"sorted_data",[1050,3637,2619],{"class":1089},[1050,3639,1636],{"class":1635},[1050,3641,3642],{"class":1331}," percentile ",[1050,3644,3645],{"class":1635},"/",[1050,3647,3225],{"class":1306},[1050,3649,1436],{"class":1089},[1050,3651,3653,3655,3658,3660,3663,3665,3668,3670,3672,3674,3676,3678,3681,3684],{"class":1052,"line":3652},159,[1050,3654,2894],{"class":1056},[1050,3656,3657],{"class":1060}," sorted_data",[1050,3659,1661],{"class":1089},[1050,3661,3662],{"class":1300},"min",[1050,3664,1197],{"class":1089},[1050,3666,3667],{"class":1331},"index",[1050,3669,1101],{"class":1089},[1050,3671,1670],{"class":1300},[1050,3673,1197],{"class":1089},[1050,3675,3635],{"class":1331},[1050,3677,2619],{"class":1089},[1050,3679,3680],{"class":1635}," -",[1050,3682,3683],{"class":1306}," 1",[1050,3685,2676],{"class":1089},[1050,3687,3689],{"class":1052,"line":3688},160,[1050,3690,1224],{"class":1060},[1050,3692,3694,3696,3699,3701,3703,3705,3707],{"class":1052,"line":3693},161,[1050,3695,1230],{"class":1189},[1050,3697,3698],{"class":1233}," count_status_codes",[1050,3700,1197],{"class":1089},[1050,3702,1240],{"class":1239},[1050,3704,1101],{"class":1089},[1050,3706,2930],{"class":1759},[1050,3708,1204],{"class":1089},[1050,3710,3712,3714,3717],{"class":1052,"line":3711},162,[1050,3713,1248],{"class":1210},[1050,3715,3716],{"class":1214},"Count occurrences of each status code",[1050,3718,1218],{"class":1210},[1050,3720,3722,3725,3727],{"class":1052,"line":3721},163,[1050,3723,3724],{"class":1060},"        status_counts ",[1050,3726,1318],{"class":1089},[1050,3728,3729],{"class":1089}," {}\n",[1050,3731,3733,3735,3738,3740,3742],{"class":1052,"line":3732},164,[1050,3734,1291],{"class":1056},[1050,3736,3737],{"class":1060}," result ",[1050,3739,1297],{"class":1056},[1050,3741,2930],{"class":1060},[1050,3743,1847],{"class":1089},[1050,3745,3747,3750,3752,3755,3757,3759,3761,3763],{"class":1052,"line":3746},165,[1050,3748,3749],{"class":1060},"            code ",[1050,3751,1318],{"class":1089},[1050,3753,3754],{"class":1060}," result",[1050,3756,1661],{"class":1089},[1050,3758,1364],{"class":1401},[1050,3760,2073],{"class":1350},[1050,3762,1364],{"class":1401},[1050,3764,2552],{"class":1089},[1050,3766,3768,3771,3773,3775,3777,3779,3782,3784,3786,3788,3790,3792,3794,3796,3799],{"class":1052,"line":3767},166,[1050,3769,3770],{"class":1060},"            status_counts",[1050,3772,1661],{"class":1089},[1050,3774,1047],{"class":1060},[1050,3776,3020],{"class":1089},[1050,3778,1282],{"class":1089},[1050,3780,3781],{"class":1060}," status_counts",[1050,3783,1090],{"class":1089},[1050,3785,1937],{"class":1331},[1050,3787,1197],{"class":1089},[1050,3789,1047],{"class":1331},[1050,3791,1101],{"class":1089},[1050,3793,2299],{"class":1306},[1050,3795,2619],{"class":1089},[1050,3797,3798],{"class":1635}," +",[1050,3800,3801],{"class":1306}," 1\n",[1050,3803,3805,3807],{"class":1052,"line":3804},167,[1050,3806,2894],{"class":1056},[1050,3808,3809],{"class":1060}," status_counts\n",[1050,3811,3813],{"class":1052,"line":3812},168,[1050,3814,1183],{"emptyLinePlaceholder":1182},[1050,3816,3818,3820,3823,3825,3828],{"class":1052,"line":3817},169,[1050,3819,1190],{"class":1189},[1050,3821,3822],{"class":1193}," BasicLoadTests",[1050,3824,1197],{"class":1089},[1050,3826,3827],{"class":1200},"LoadTestingBase",[1050,3829,1204],{"class":1089},[1050,3831,3833,3835,3838],{"class":1052,"line":3832},170,[1050,3834,1211],{"class":1210},[1050,3836,3837],{"class":1214},"Basic load testing scenarios",[1050,3839,1218],{"class":1210},[1050,3841,3843],{"class":1052,"line":3842},171,[1050,3844,1224],{"class":1060},[1050,3846,3848,3850,3853,3855,3857],{"class":1052,"line":3847},172,[1050,3849,1230],{"class":1189},[1050,3851,3852],{"class":1233}," test_homepage_load",[1050,3854,1197],{"class":1089},[1050,3856,1240],{"class":1239},[1050,3858,1204],{"class":1089},[1050,3860,3862,3864,3867],{"class":1052,"line":3861},173,[1050,3863,1248],{"class":1210},[1050,3865,3866],{"class":1214},"Test homepage under load",[1050,3868,1218],{"class":1210},[1050,3870,3872],{"class":1052,"line":3871},174,[1050,3873,1259],{"class":1060},[1050,3875,3877,3879,3881,3883,3885,3888],{"class":1052,"line":3876},175,[1050,3878,2426],{"class":1060},[1050,3880,1318],{"class":1089},[1050,3882,2481],{"class":1272},[1050,3884,1090],{"class":1089},[1050,3886,3887],{"class":1331},"run_load_test",[1050,3889,1335],{"class":1089},[1050,3891,3893,3896,3898,3900,3902,3904],{"class":1052,"line":3892},176,[1050,3894,3895],{"class":1341},"            url",[1050,3897,1318],{"class":1089},[1050,3899,1364],{"class":1401},[1050,3901,3645],{"class":1350},[1050,3903,1364],{"class":1401},[1050,3905,1367],{"class":1089},[1050,3907,3909,3912,3914,3917],{"class":1052,"line":3908},177,[1050,3910,3911],{"class":1341},"            num_requests",[1050,3913,1318],{"class":1089},[1050,3915,3916],{"class":1306},"50",[1050,3918,1367],{"class":1089},[1050,3920,3922,3925,3927],{"class":1052,"line":3921},178,[1050,3923,3924],{"class":1341},"            concurrent_users",[1050,3926,1318],{"class":1089},[1050,3928,3929],{"class":1306},"5\n",[1050,3931,3933],{"class":1052,"line":3932},179,[1050,3934,3935],{"class":1089},"        )\n",[1050,3937,3939],{"class":1052,"line":3938},180,[1050,3940,1259],{"class":1060},[1050,3942,3944],{"class":1052,"line":3943},181,[1050,3945,3946],{"class":1265},"        # Assert performance requirements\n",[1050,3948,3950,3952,3954,3957,3959,3961,3963,3965,3967,3969,3972,3975],{"class":1052,"line":3949},182,[1050,3951,1273],{"class":1272},[1050,3953,1090],{"class":1089},[1050,3955,3956],{"class":1331},"assertGreaterEqual",[1050,3958,1197],{"class":1089},[1050,3960,2906],{"class":1331},[1050,3962,1661],{"class":1089},[1050,3964,1364],{"class":1401},[1050,3966,3197],{"class":1350},[1050,3968,1364],{"class":1401},[1050,3970,3971],{"class":1089},"],",[1050,3973,3974],{"class":1306}," 95.0",[1050,3976,1436],{"class":1089},[1050,3978,3980,3982,3984,3987,3989,3991,3993,3995,3997,3999,4001,4004,4006],{"class":1052,"line":3979},183,[1050,3981,1273],{"class":1272},[1050,3983,1090],{"class":1089},[1050,3985,3986],{"class":1331},"assertLess",[1050,3988,1197],{"class":1089},[1050,3990,2906],{"class":1331},[1050,3992,1661],{"class":1089},[1050,3994,1364],{"class":1401},[1050,3996,3246],{"class":1350},[1050,3998,1364],{"class":1401},[1050,4000,3971],{"class":1089},[1050,4002,4003],{"class":1306}," 2.0",[1050,4005,2619],{"class":1089},[1050,4007,4008],{"class":1265},"  # \u003C 2 seconds\n",[1050,4010,4012,4014,4016,4018,4020,4022,4024,4026,4028,4030,4032,4035,4037],{"class":1052,"line":4011},184,[1050,4013,1273],{"class":1272},[1050,4015,1090],{"class":1089},[1050,4017,3986],{"class":1331},[1050,4019,1197],{"class":1089},[1050,4021,2906],{"class":1331},[1050,4023,1661],{"class":1089},[1050,4025,1364],{"class":1401},[1050,4027,3351],{"class":1350},[1050,4029,1364],{"class":1401},[1050,4031,3971],{"class":1089},[1050,4033,4034],{"class":1306}," 5.0",[1050,4036,2619],{"class":1089},[1050,4038,4039],{"class":1265},"  # 95% \u003C 5 seconds\n",[1050,4041,4043,4045,4047,4050,4052,4054,4056,4058,4060,4062,4064,4067,4069],{"class":1052,"line":4042},185,[1050,4044,1273],{"class":1272},[1050,4046,1090],{"class":1089},[1050,4048,4049],{"class":1331},"assertGreater",[1050,4051,1197],{"class":1089},[1050,4053,2906],{"class":1331},[1050,4055,1661],{"class":1089},[1050,4057,1364],{"class":1401},[1050,4059,3421],{"class":1350},[1050,4061,1364],{"class":1401},[1050,4063,3971],{"class":1089},[1050,4065,4066],{"class":1306}," 10",[1050,4068,2619],{"class":1089},[1050,4070,4071],{"class":1265},"  # > 10 RPS\n",[1050,4073,4075],{"class":1052,"line":4074},186,[1050,4076,1259],{"class":1060},[1050,4078,4080,4083,4085,4087,4090],{"class":1052,"line":4079},187,[1050,4081,4082],{"class":1300},"        print",[1050,4084,1197],{"class":1089},[1050,4086,1347],{"class":1189},[1050,4088,4089],{"class":1350},"\"Homepage Load Test Results:\"",[1050,4091,1436],{"class":1089},[1050,4093,4095,4097,4099,4101,4104,4106,4108,4110,4112,4114,4116,4118,4121,4123,4126],{"class":1052,"line":4094},188,[1050,4096,4082],{"class":1300},[1050,4098,1197],{"class":1089},[1050,4100,1347],{"class":1189},[1050,4102,4103],{"class":1350},"\"Success Rate: ",[1050,4105,1355],{"class":1354},[1050,4107,2906],{"class":1331},[1050,4109,1661],{"class":1089},[1050,4111,1364],{"class":1401},[1050,4113,3197],{"class":1350},[1050,4115,1364],{"class":1401},[1050,4117,3020],{"class":1089},[1050,4119,4120],{"class":1189},":.1f",[1050,4122,1361],{"class":1354},[1050,4124,4125],{"class":1350},"%\"",[1050,4127,1436],{"class":1089},[1050,4129,4131,4133,4135,4137,4140,4142,4144,4146,4148,4150,4152,4154,4157,4159,4162],{"class":1052,"line":4130},189,[1050,4132,4082],{"class":1300},[1050,4134,1197],{"class":1089},[1050,4136,1347],{"class":1189},[1050,4138,4139],{"class":1350},"\"Average Response Time: ",[1050,4141,1355],{"class":1354},[1050,4143,2906],{"class":1331},[1050,4145,1661],{"class":1089},[1050,4147,1364],{"class":1401},[1050,4149,3246],{"class":1350},[1050,4151,1364],{"class":1401},[1050,4153,3020],{"class":1089},[1050,4155,4156],{"class":1189},":.3f",[1050,4158,1361],{"class":1354},[1050,4160,4161],{"class":1350},"s\"",[1050,4163,1436],{"class":1089},[1050,4165,4167,4169,4171,4173,4176,4178,4180,4182,4184,4186,4188,4190,4192,4194,4196],{"class":1052,"line":4166},190,[1050,4168,4082],{"class":1300},[1050,4170,1197],{"class":1089},[1050,4172,1347],{"class":1189},[1050,4174,4175],{"class":1350},"\"95th Percentile: ",[1050,4177,1355],{"class":1354},[1050,4179,2906],{"class":1331},[1050,4181,1661],{"class":1089},[1050,4183,1364],{"class":1401},[1050,4185,3351],{"class":1350},[1050,4187,1364],{"class":1401},[1050,4189,3020],{"class":1089},[1050,4191,4156],{"class":1189},[1050,4193,1361],{"class":1354},[1050,4195,4161],{"class":1350},[1050,4197,1436],{"class":1089},[1050,4199,4201,4203,4205,4207,4210,4212,4214,4216,4218,4220,4222,4224,4226,4228,4230],{"class":1052,"line":4200},191,[1050,4202,4082],{"class":1300},[1050,4204,1197],{"class":1089},[1050,4206,1347],{"class":1189},[1050,4208,4209],{"class":1350},"\"Requests/Second: ",[1050,4211,1355],{"class":1354},[1050,4213,2906],{"class":1331},[1050,4215,1661],{"class":1089},[1050,4217,1364],{"class":1401},[1050,4219,3421],{"class":1350},[1050,4221,1364],{"class":1401},[1050,4223,3020],{"class":1089},[1050,4225,4120],{"class":1189},[1050,4227,1361],{"class":1354},[1050,4229,2026],{"class":1350},[1050,4231,1436],{"class":1089},[1050,4233,4235],{"class":1052,"line":4234},192,[1050,4236,1224],{"class":1060},[1050,4238,4240,4242,4245,4247,4249],{"class":1052,"line":4239},193,[1050,4241,1230],{"class":1189},[1050,4243,4244],{"class":1233}," test_blog_list_load",[1050,4246,1197],{"class":1089},[1050,4248,1240],{"class":1239},[1050,4250,1204],{"class":1089},[1050,4252,4254,4256,4259],{"class":1052,"line":4253},194,[1050,4255,1248],{"class":1210},[1050,4257,4258],{"class":1214},"Test blog list page under load",[1050,4260,1218],{"class":1210},[1050,4262,4264],{"class":1052,"line":4263},195,[1050,4265,1259],{"class":1060},[1050,4267,4269,4271,4273,4275,4277,4279],{"class":1052,"line":4268},196,[1050,4270,2426],{"class":1060},[1050,4272,1318],{"class":1089},[1050,4274,2481],{"class":1272},[1050,4276,1090],{"class":1089},[1050,4278,3887],{"class":1331},[1050,4280,1335],{"class":1089},[1050,4282,4284,4286,4288,4290,4293,4295],{"class":1052,"line":4283},197,[1050,4285,3895],{"class":1341},[1050,4287,1318],{"class":1089},[1050,4289,1364],{"class":1401},[1050,4291,4292],{"class":1350},"/blog/",[1050,4294,1364],{"class":1401},[1050,4296,1367],{"class":1089},[1050,4298,4300,4302,4304,4306],{"class":1052,"line":4299},198,[1050,4301,3911],{"class":1341},[1050,4303,1318],{"class":1089},[1050,4305,1565],{"class":1306},[1050,4307,1367],{"class":1089},[1050,4309,4311,4313,4315],{"class":1052,"line":4310},199,[1050,4312,3924],{"class":1341},[1050,4314,1318],{"class":1089},[1050,4316,4317],{"class":1306},"10\n",[1050,4319,4321],{"class":1052,"line":4320},200,[1050,4322,3935],{"class":1089},[1050,4324,4326],{"class":1052,"line":4325},201,[1050,4327,1259],{"class":1060},[1050,4329,4331],{"class":1052,"line":4330},202,[1050,4332,4333],{"class":1265},"        # Blog list might be slower due to database queries\n",[1050,4335,4337,4339,4341,4343,4345,4347,4349,4351,4353,4355,4357,4360],{"class":1052,"line":4336},203,[1050,4338,1273],{"class":1272},[1050,4340,1090],{"class":1089},[1050,4342,3956],{"class":1331},[1050,4344,1197],{"class":1089},[1050,4346,2906],{"class":1331},[1050,4348,1661],{"class":1089},[1050,4350,1364],{"class":1401},[1050,4352,3197],{"class":1350},[1050,4354,1364],{"class":1401},[1050,4356,3971],{"class":1089},[1050,4358,4359],{"class":1306}," 90.0",[1050,4361,1436],{"class":1089},[1050,4363,4365,4367,4369,4371,4373,4375,4377,4379,4381,4383,4385,4388],{"class":1052,"line":4364},204,[1050,4366,1273],{"class":1272},[1050,4368,1090],{"class":1089},[1050,4370,3986],{"class":1331},[1050,4372,1197],{"class":1089},[1050,4374,2906],{"class":1331},[1050,4376,1661],{"class":1089},[1050,4378,1364],{"class":1401},[1050,4380,3246],{"class":1350},[1050,4382,1364],{"class":1401},[1050,4384,3971],{"class":1089},[1050,4386,4387],{"class":1306}," 3.0",[1050,4389,1436],{"class":1089},[1050,4391,4393,4395,4397,4399,4401,4403,4405,4407,4409,4411,4413,4416],{"class":1052,"line":4392},205,[1050,4394,1273],{"class":1272},[1050,4396,1090],{"class":1089},[1050,4398,3986],{"class":1331},[1050,4400,1197],{"class":1089},[1050,4402,2906],{"class":1331},[1050,4404,1661],{"class":1089},[1050,4406,1364],{"class":1401},[1050,4408,3351],{"class":1350},[1050,4410,1364],{"class":1401},[1050,4412,3971],{"class":1089},[1050,4414,4415],{"class":1306}," 8.0",[1050,4417,1436],{"class":1089},[1050,4419,4421],{"class":1052,"line":4420},206,[1050,4422,1259],{"class":1060},[1050,4424,4426,4428,4430,4432,4435],{"class":1052,"line":4425},207,[1050,4427,4082],{"class":1300},[1050,4429,1197],{"class":1089},[1050,4431,1347],{"class":1189},[1050,4433,4434],{"class":1350},"\"Blog List Load Test Results:\"",[1050,4436,1436],{"class":1089},[1050,4438,4440,4442,4444,4446,4448,4450,4452,4454,4456,4458,4460,4462,4464,4466,4468],{"class":1052,"line":4439},208,[1050,4441,4082],{"class":1300},[1050,4443,1197],{"class":1089},[1050,4445,1347],{"class":1189},[1050,4447,4103],{"class":1350},[1050,4449,1355],{"class":1354},[1050,4451,2906],{"class":1331},[1050,4453,1661],{"class":1089},[1050,4455,1364],{"class":1401},[1050,4457,3197],{"class":1350},[1050,4459,1364],{"class":1401},[1050,4461,3020],{"class":1089},[1050,4463,4120],{"class":1189},[1050,4465,1361],{"class":1354},[1050,4467,4125],{"class":1350},[1050,4469,1436],{"class":1089},[1050,4471,4473,4475,4477,4479,4481,4483,4485,4487,4489,4491,4493,4495,4497,4499,4501],{"class":1052,"line":4472},209,[1050,4474,4082],{"class":1300},[1050,4476,1197],{"class":1089},[1050,4478,1347],{"class":1189},[1050,4480,4139],{"class":1350},[1050,4482,1355],{"class":1354},[1050,4484,2906],{"class":1331},[1050,4486,1661],{"class":1089},[1050,4488,1364],{"class":1401},[1050,4490,3246],{"class":1350},[1050,4492,1364],{"class":1401},[1050,4494,3020],{"class":1089},[1050,4496,4156],{"class":1189},[1050,4498,1361],{"class":1354},[1050,4500,4161],{"class":1350},[1050,4502,1436],{"class":1089},[1050,4504,4506,4508,4510,4512,4515,4517,4519,4521,4523,4525,4527,4529,4531,4533],{"class":1052,"line":4505},210,[1050,4507,4082],{"class":1300},[1050,4509,1197],{"class":1089},[1050,4511,1347],{"class":1189},[1050,4513,4514],{"class":1350},"\"Failed Requests: ",[1050,4516,1355],{"class":1354},[1050,4518,2906],{"class":1331},[1050,4520,1661],{"class":1089},[1050,4522,1364],{"class":1401},[1050,4524,3177],{"class":1350},[1050,4526,1364],{"class":1401},[1050,4528,3020],{"class":1089},[1050,4530,1361],{"class":1354},[1050,4532,2026],{"class":1350},[1050,4534,1436],{"class":1089},[1050,4536,4538],{"class":1052,"line":4537},211,[1050,4539,1224],{"class":1060},[1050,4541,4543,4545,4548,4550,4552],{"class":1052,"line":4542},212,[1050,4544,1230],{"class":1189},[1050,4546,4547],{"class":1233}," test_post_detail_load",[1050,4549,1197],{"class":1089},[1050,4551,1240],{"class":1239},[1050,4553,1204],{"class":1089},[1050,4555,4557,4559,4562],{"class":1052,"line":4556},213,[1050,4558,1248],{"class":1210},[1050,4560,4561],{"class":1214},"Test individual post pages under load",[1050,4563,1218],{"class":1210},[1050,4565,4567],{"class":1052,"line":4566},214,[1050,4568,1259],{"class":1060},[1050,4570,4572],{"class":1052,"line":4571},215,[1050,4573,4574],{"class":1265},"        # Test multiple different posts\n",[1050,4576,4578,4581,4583,4585,4587,4590,4592,4594,4596,4599,4601,4604,4606,4609,4611,4613,4615,4617,4620,4622],{"class":1052,"line":4577},216,[1050,4579,4580],{"class":1060},"        post_urls ",[1050,4582,1318],{"class":1089},[1050,4584,2643],{"class":1089},[1050,4586,1347],{"class":1189},[1050,4588,4589],{"class":1350},"'/blog/",[1050,4591,1355],{"class":1354},[1050,4593,1735],{"class":1060},[1050,4595,1090],{"class":1089},[1050,4597,4598],{"class":1278},"slug",[1050,4600,1361],{"class":1354},[1050,4602,4603],{"class":1350},"/'",[1050,4605,2661],{"class":1056},[1050,4607,4608],{"class":1060}," post ",[1050,4610,1297],{"class":1056},[1050,4612,2481],{"class":1272},[1050,4614,1090],{"class":1089},[1050,4616,1545],{"class":1278},[1050,4618,4619],{"class":1089},"[:",[1050,4621,1307],{"class":1306},[1050,4623,3071],{"class":1089},[1050,4625,4627],{"class":1052,"line":4626},217,[1050,4628,1259],{"class":1060},[1050,4630,4632,4635,4637],{"class":1052,"line":4631},218,[1050,4633,4634],{"class":1060},"        all_results ",[1050,4636,1318],{"class":1089},[1050,4638,1285],{"class":1089},[1050,4640,4642,4644,4647,4649,4652],{"class":1052,"line":4641},219,[1050,4643,1291],{"class":1056},[1050,4645,4646],{"class":1060}," url ",[1050,4648,1297],{"class":1056},[1050,4650,4651],{"class":1060}," post_urls",[1050,4653,1847],{"class":1089},[1050,4655,4657,4660,4662,4664,4666,4668],{"class":1052,"line":4656},220,[1050,4658,4659],{"class":1060},"            results ",[1050,4661,1318],{"class":1089},[1050,4663,2481],{"class":1272},[1050,4665,1090],{"class":1089},[1050,4667,3887],{"class":1331},[1050,4669,1335],{"class":1089},[1050,4671,4673,4676,4678,4680],{"class":1052,"line":4672},221,[1050,4674,4675],{"class":1341},"                url",[1050,4677,1318],{"class":1089},[1050,4679,1942],{"class":1331},[1050,4681,1367],{"class":1089},[1050,4683,4685,4688,4690,4693],{"class":1052,"line":4684},222,[1050,4686,4687],{"class":1341},"                num_requests",[1050,4689,1318],{"class":1089},[1050,4691,4692],{"class":1306},"20",[1050,4694,1367],{"class":1089},[1050,4696,4698,4701,4703],{"class":1052,"line":4697},223,[1050,4699,4700],{"class":1341},"                concurrent_users",[1050,4702,1318],{"class":1089},[1050,4704,3929],{"class":1306},[1050,4706,4708],{"class":1052,"line":4707},224,[1050,4709,1413],{"class":1089},[1050,4711,4713,4716,4718,4720,4722,4724],{"class":1052,"line":4712},225,[1050,4714,4715],{"class":1060},"            all_results",[1050,4717,1090],{"class":1089},[1050,4719,1428],{"class":1331},[1050,4721,1197],{"class":1089},[1050,4723,2906],{"class":1331},[1050,4725,1436],{"class":1089},[1050,4727,4729],{"class":1052,"line":4728},226,[1050,4730,1259],{"class":1060},[1050,4732,4734],{"class":1052,"line":4733},227,[1050,4735,4736],{"class":1265},"        # Analyze combined results\n",[1050,4738,4740,4743,4745,4747,4749,4751,4753,4755,4757,4759,4761,4763,4765,4767,4770,4772,4774,4776,4778,4781],{"class":1052,"line":4739},228,[1050,4741,4742],{"class":1060},"        avg_success_rate ",[1050,4744,1318],{"class":1089},[1050,4746,3438],{"class":1300},[1050,4748,1197],{"class":1089},[1050,4750,3009],{"class":1331},[1050,4752,1661],{"class":1089},[1050,4754,1364],{"class":1401},[1050,4756,3197],{"class":1350},[1050,4758,1364],{"class":1401},[1050,4760,3020],{"class":1089},[1050,4762,2661],{"class":1056},[1050,4764,3025],{"class":1331},[1050,4766,1297],{"class":1056},[1050,4768,4769],{"class":1331}," all_results",[1050,4771,2619],{"class":1089},[1050,4773,3212],{"class":1635},[1050,4775,1670],{"class":1300},[1050,4777,1197],{"class":1089},[1050,4779,4780],{"class":1331},"all_results",[1050,4782,1436],{"class":1089},[1050,4784,4786,4789,4791,4793,4795,4797,4799,4801,4803,4805,4807,4809,4811,4813,4815,4817,4819,4821,4823,4825],{"class":1052,"line":4785},229,[1050,4787,4788],{"class":1060},"        avg_response_time ",[1050,4790,1318],{"class":1089},[1050,4792,3438],{"class":1300},[1050,4794,1197],{"class":1089},[1050,4796,3009],{"class":1331},[1050,4798,1661],{"class":1089},[1050,4800,1364],{"class":1401},[1050,4802,3246],{"class":1350},[1050,4804,1364],{"class":1401},[1050,4806,3020],{"class":1089},[1050,4808,2661],{"class":1056},[1050,4810,3025],{"class":1331},[1050,4812,1297],{"class":1056},[1050,4814,4769],{"class":1331},[1050,4816,2619],{"class":1089},[1050,4818,3212],{"class":1635},[1050,4820,1670],{"class":1300},[1050,4822,1197],{"class":1089},[1050,4824,4780],{"class":1331},[1050,4826,1436],{"class":1089},[1050,4828,4830],{"class":1052,"line":4829},230,[1050,4831,1259],{"class":1060},[1050,4833,4835,4837,4839,4841,4843,4846,4848,4850],{"class":1052,"line":4834},231,[1050,4836,1273],{"class":1272},[1050,4838,1090],{"class":1089},[1050,4840,3956],{"class":1331},[1050,4842,1197],{"class":1089},[1050,4844,4845],{"class":1331},"avg_success_rate",[1050,4847,1101],{"class":1089},[1050,4849,3974],{"class":1306},[1050,4851,1436],{"class":1089},[1050,4853,4855,4857,4859,4861,4863,4865,4867,4869],{"class":1052,"line":4854},232,[1050,4856,1273],{"class":1272},[1050,4858,1090],{"class":1089},[1050,4860,3986],{"class":1331},[1050,4862,1197],{"class":1089},[1050,4864,3246],{"class":1331},[1050,4866,1101],{"class":1089},[1050,4868,4003],{"class":1306},[1050,4870,1436],{"class":1089},[1050,4872,4874],{"class":1052,"line":4873},233,[1050,4875,1259],{"class":1060},[1050,4877,4879,4881,4883,4885,4888],{"class":1052,"line":4878},234,[1050,4880,4082],{"class":1300},[1050,4882,1197],{"class":1089},[1050,4884,1347],{"class":1189},[1050,4886,4887],{"class":1350},"\"Post Detail Load Test Results (10 different posts):\"",[1050,4889,1436],{"class":1089},[1050,4891,4893,4895,4897,4899,4902,4904,4906,4908,4910,4912],{"class":1052,"line":4892},235,[1050,4894,4082],{"class":1300},[1050,4896,1197],{"class":1089},[1050,4898,1347],{"class":1189},[1050,4900,4901],{"class":1350},"\"Average Success Rate: ",[1050,4903,1355],{"class":1354},[1050,4905,4845],{"class":1331},[1050,4907,4120],{"class":1189},[1050,4909,1361],{"class":1354},[1050,4911,4125],{"class":1350},[1050,4913,1436],{"class":1089},[1050,4915,4917,4919,4921,4923,4925,4927,4929,4931,4933,4935],{"class":1052,"line":4916},236,[1050,4918,4082],{"class":1300},[1050,4920,1197],{"class":1089},[1050,4922,1347],{"class":1189},[1050,4924,4139],{"class":1350},[1050,4926,1355],{"class":1354},[1050,4928,3246],{"class":1331},[1050,4930,4156],{"class":1189},[1050,4932,1361],{"class":1354},[1050,4934,4161],{"class":1350},[1050,4936,1436],{"class":1089},[1050,4938,4940],{"class":1052,"line":4939},237,[1050,4941,1224],{"class":1060},[1050,4943,4945,4947,4950,4952,4954],{"class":1052,"line":4944},238,[1050,4946,1230],{"class":1189},[1050,4948,4949],{"class":1233}," test_authenticated_user_load",[1050,4951,1197],{"class":1089},[1050,4953,1240],{"class":1239},[1050,4955,1204],{"class":1089},[1050,4957,4959,4961,4964],{"class":1052,"line":4958},239,[1050,4960,1248],{"class":1210},[1050,4962,4963],{"class":1214},"Test load with authenticated users",[1050,4965,1218],{"class":1210},[1050,4967,4969],{"class":1052,"line":4968},240,[1050,4970,1259],{"class":1060},[1050,4972,4974,4976,4978,4980,4982,4984],{"class":1052,"line":4973},241,[1050,4975,2426],{"class":1060},[1050,4977,1318],{"class":1089},[1050,4979,2481],{"class":1272},[1050,4981,1090],{"class":1089},[1050,4983,3887],{"class":1331},[1050,4985,1335],{"class":1089},[1050,4987,4989,4991,4993,4995,4998,5000],{"class":1052,"line":4988},242,[1050,4990,3895],{"class":1341},[1050,4992,1318],{"class":1089},[1050,4994,1364],{"class":1401},[1050,4996,4997],{"class":1350},"/dashboard/",[1050,4999,1364],{"class":1401},[1050,5001,1367],{"class":1089},[1050,5003,5005,5007,5009,5011],{"class":1052,"line":5004},243,[1050,5006,3911],{"class":1341},[1050,5008,1318],{"class":1089},[1050,5010,3916],{"class":1306},[1050,5012,1367],{"class":1089},[1050,5014,5016,5018,5020,5023],{"class":1052,"line":5015},244,[1050,5017,3924],{"class":1341},[1050,5019,1318],{"class":1089},[1050,5021,5022],{"class":1306},"5",[1050,5024,1367],{"class":1089},[1050,5026,5028,5031,5033],{"class":1052,"line":5027},245,[1050,5029,5030],{"class":1341},"            authenticated",[1050,5032,1318],{"class":1089},[1050,5034,5035],{"class":1784},"True\n",[1050,5037,5039],{"class":1052,"line":5038},246,[1050,5040,3935],{"class":1089},[1050,5042,5044],{"class":1052,"line":5043},247,[1050,5045,1259],{"class":1060},[1050,5047,5049],{"class":1052,"line":5048},248,[1050,5050,5051],{"class":1265},"        # Authenticated requests might be slower due to session handling\n",[1050,5053,5055,5057,5059,5061,5063,5065,5067,5069,5071,5073,5075,5077],{"class":1052,"line":5054},249,[1050,5056,1273],{"class":1272},[1050,5058,1090],{"class":1089},[1050,5060,3956],{"class":1331},[1050,5062,1197],{"class":1089},[1050,5064,2906],{"class":1331},[1050,5066,1661],{"class":1089},[1050,5068,1364],{"class":1401},[1050,5070,3197],{"class":1350},[1050,5072,1364],{"class":1401},[1050,5074,3971],{"class":1089},[1050,5076,4359],{"class":1306},[1050,5078,1436],{"class":1089},[1050,5080,5082,5084,5086,5088,5090,5092,5094,5096,5098,5100,5102,5104],{"class":1052,"line":5081},250,[1050,5083,1273],{"class":1272},[1050,5085,1090],{"class":1089},[1050,5087,3986],{"class":1331},[1050,5089,1197],{"class":1089},[1050,5091,2906],{"class":1331},[1050,5093,1661],{"class":1089},[1050,5095,1364],{"class":1401},[1050,5097,3246],{"class":1350},[1050,5099,1364],{"class":1401},[1050,5101,3971],{"class":1089},[1050,5103,4387],{"class":1306},[1050,5105,1436],{"class":1089},[1050,5107,5109],{"class":1052,"line":5108},251,[1050,5110,1259],{"class":1060},[1050,5112,5114,5116,5118,5120,5123],{"class":1052,"line":5113},252,[1050,5115,4082],{"class":1300},[1050,5117,1197],{"class":1089},[1050,5119,1347],{"class":1189},[1050,5121,5122],{"class":1350},"\"Authenticated User Load Test Results:\"",[1050,5124,1436],{"class":1089},[1050,5126,5128,5130,5132,5134,5136,5138,5140,5142,5144,5146,5148,5150,5152,5154,5156],{"class":1052,"line":5127},253,[1050,5129,4082],{"class":1300},[1050,5131,1197],{"class":1089},[1050,5133,1347],{"class":1189},[1050,5135,4103],{"class":1350},[1050,5137,1355],{"class":1354},[1050,5139,2906],{"class":1331},[1050,5141,1661],{"class":1089},[1050,5143,1364],{"class":1401},[1050,5145,3197],{"class":1350},[1050,5147,1364],{"class":1401},[1050,5149,3020],{"class":1089},[1050,5151,4120],{"class":1189},[1050,5153,1361],{"class":1354},[1050,5155,4125],{"class":1350},[1050,5157,1436],{"class":1089},[1050,5159,5161,5163,5165,5167,5169,5171,5173,5175,5177,5179,5181,5183,5185,5187,5189],{"class":1052,"line":5160},254,[1050,5162,4082],{"class":1300},[1050,5164,1197],{"class":1089},[1050,5166,1347],{"class":1189},[1050,5168,4139],{"class":1350},[1050,5170,1355],{"class":1354},[1050,5172,2906],{"class":1331},[1050,5174,1661],{"class":1089},[1050,5176,1364],{"class":1401},[1050,5178,3246],{"class":1350},[1050,5180,1364],{"class":1401},[1050,5182,3020],{"class":1089},[1050,5184,4156],{"class":1189},[1050,5186,1361],{"class":1354},[1050,5188,4161],{"class":1350},[1050,5190,1436],{"class":1089},[1030,5192,5194],{"id":5193},"stress-testing","Stress Testing",[1035,5196,5198],{"id":5197},"testing-application-limits","Testing Application Limits",[1040,5200,5202],{"className":1042,"code":5201,"language":1044,"meta":1045,"style":1045},"class StressTests(LoadTestingBase):\n    \"\"\"Stress testing to find application limits\"\"\"\n    \n    def test_increasing_load_stress(self):\n        \"\"\"Test with increasing load to find breaking point\"\"\"\n        \n        load_levels = [\n            (10, 2),   # 10 requests, 2 concurrent users\n            (50, 5),   # 50 requests, 5 concurrent users\n            (100, 10), # 100 requests, 10 concurrent users\n            (200, 20), # 200 requests, 20 concurrent users\n            (500, 50), # 500 requests, 50 concurrent users\n        ]\n        \n        results_by_load = []\n        \n        for num_requests, concurrent_users in load_levels:\n            print(f\"Testing load: {num_requests} requests, {concurrent_users} concurrent users\")\n            \n            results = self.run_load_test(\n                url='/blog/',\n                num_requests=num_requests,\n                concurrent_users=concurrent_users\n            )\n            \n            results['load_level'] = (num_requests, concurrent_users)\n            results_by_load.append(results)\n            \n            print(f\"Success Rate: {results['success_rate']:.1f}%, \"\n                  f\"Avg Response Time: {results['avg_response_time']:.3f}s\")\n            \n            # Stop if success rate drops below threshold\n            if results['success_rate'] \u003C 80.0:\n                print(f\"Breaking point reached at {num_requests} requests, {concurrent_users} users\")\n                break\n            \n            # Brief pause between load levels\n            time.sleep(2)\n        \n        # Analyze degradation pattern\n        self.analyze_performance_degradation(results_by_load)\n    \n    def analyze_performance_degradation(self, results_by_load):\n        \"\"\"Analyze how performance degrades with increased load\"\"\"\n        \n        print(\"\\nPerformance Degradation Analysis:\")\n        print(\"Load Level\\t\\tSuccess Rate\\tAvg Response Time\\tP95 Response Time\")\n        print(\"-\" * 80)\n        \n        for results in results_by_load:\n            load = results['load_level']\n            print(f\"{load[0]:3d} req, {load[1]:2d} users\\t\"\n                  f\"{results['success_rate']:6.1f}%\\t\\t\"\n                  f\"{results['avg_response_time']:8.3f}s\\t\\t\"\n                  f\"{results['p95_response_time']:8.3f}s\")\n        \n        # Check for acceptable degradation\n        if len(results_by_load) >= 2:\n            first_result = results_by_load[0]\n            last_result = results_by_load[-1]\n            \n            response_time_increase = (\n                last_result['avg_response_time'] / first_result['avg_response_time']\n            )\n            \n            # Response time shouldn't increase more than 3x under reasonable load\n            if response_time_increase > 3.0:\n                print(f\"WARNING: Response time increased {response_time_increase:.1f}x under load\")\n    \n    def test_memory_stress(self):\n        \"\"\"Test memory usage under stress\"\"\"\n        \n        import psutil\n        import os\n        \n        process = psutil.Process(os.getpid())\n        \n        # Measure initial memory\n        initial_memory = process.memory_info().rss / 1024 / 1024  # MB\n        \n        # Run memory-intensive operations\n        results = self.run_load_test(\n            url='/blog/',\n            num_requests=200,\n            concurrent_users=20\n        )\n        \n        # Measure final memory\n        final_memory = process.memory_info().rss / 1024 / 1024  # MB\n        memory_increase = final_memory - initial_memory\n        \n        print(f\"Memory Stress Test Results:\")\n        print(f\"Initial Memory: {initial_memory:.1f} MB\")\n        print(f\"Final Memory: {final_memory:.1f} MB\")\n        print(f\"Memory Increase: {memory_increase:.1f} MB\")\n        print(f\"Success Rate: {results['success_rate']:.1f}%\")\n        \n        # Memory increase should be reasonable\n        self.assertLess(memory_increase, 200, f\"Memory increased by {memory_increase:.1f} MB\")\n        self.assertGreaterEqual(results['success_rate'], 85.0)\n    \n    def test_database_connection_stress(self):\n        \"\"\"Test database connection handling under stress\"\"\"\n        \n        from django.db import connections\n        from django.test.utils import override_settings\n        \n        # Test with limited database connections\n        with override_settings(\n            DATABASES={\n                'default': {\n                    **connections['default'].settings_dict,\n                    'OPTIONS': {\n                        'MAX_CONNS': 10,  # Limit connections\n                    }\n                }\n            }\n        ):\n            results = self.run_load_test(\n                url='/blog/',\n                num_requests=100,\n                concurrent_users=15  # More users than DB connections\n            )\n            \n            print(f\"Database Connection Stress Test:\")\n            print(f\"Success Rate: {results['success_rate']:.1f}%\")\n            print(f\"Failed Requests: {results['failed_requests']}\")\n            \n            # Should handle connection limits gracefully\n            self.assertGreaterEqual(results['success_rate'], 80.0)\n",[1047,5203,5204,5217,5226,5230,5243,5252,5256,5266,5284,5300,5315,5332,5348,5353,5357,5366,5370,5388,5420,5424,5438,5452,5462,5471,5475,5479,5508,5523,5527,5558,5588,5592,5597,5620,5651,5656,5660,5665,5682,5686,5691,5707,5711,5729,5738,5742,5760,5792,5811,5815,5827,5846,5899,5930,5962,5990,5994,5999,6018,6033,6050,6054,6064,6094,6098,6102,6107,6121,6146,6150,6163,6172,6176,6184,6191,6195,6223,6227,6232,6264,6268,6273,6287,6301,6311,6320,6324,6328,6333,6360,6375,6379,6392,6417,6441,6465,6497,6501,6506,6541,6568,6572,6585,6594,6598,6614,6632,6636,6641,6650,6658,6671,6695,6709,6727,6732,6737,6741,6746,6760,6774,6784,6796,6800,6804,6817,6849,6879,6883,6888],{"__ignoreMap":1045},[1050,5205,5206,5208,5211,5213,5215],{"class":1052,"line":1053},[1050,5207,1190],{"class":1189},[1050,5209,5210],{"class":1193}," StressTests",[1050,5212,1197],{"class":1089},[1050,5214,3827],{"class":1200},[1050,5216,1204],{"class":1089},[1050,5218,5219,5221,5224],{"class":1052,"line":1064},[1050,5220,1211],{"class":1210},[1050,5222,5223],{"class":1214},"Stress testing to find application limits",[1050,5225,1218],{"class":1210},[1050,5227,5228],{"class":1052,"line":1072},[1050,5229,1224],{"class":1060},[1050,5231,5232,5234,5237,5239,5241],{"class":1052,"line":1080},[1050,5233,1230],{"class":1189},[1050,5235,5236],{"class":1233}," test_increasing_load_stress",[1050,5238,1197],{"class":1089},[1050,5240,1240],{"class":1239},[1050,5242,1204],{"class":1089},[1050,5244,5245,5247,5250],{"class":1052,"line":1107},[1050,5246,1248],{"class":1210},[1050,5248,5249],{"class":1214},"Test with increasing load to find breaking point",[1050,5251,1218],{"class":1210},[1050,5253,5254],{"class":1052,"line":1130},[1050,5255,1259],{"class":1060},[1050,5257,5258,5261,5263],{"class":1052,"line":1152},[1050,5259,5260],{"class":1060},"        load_levels ",[1050,5262,1318],{"class":1089},[1050,5264,5265],{"class":1089}," [\n",[1050,5267,5268,5271,5273,5275,5278,5281],{"class":1052,"line":1179},[1050,5269,5270],{"class":1089},"            (",[1050,5272,1307],{"class":1306},[1050,5274,1101],{"class":1089},[1050,5276,5277],{"class":1306}," 2",[1050,5279,5280],{"class":1089},"),",[1050,5282,5283],{"class":1265},"   # 10 requests, 2 concurrent users\n",[1050,5285,5286,5288,5290,5292,5295,5297],{"class":1052,"line":1186},[1050,5287,5270],{"class":1089},[1050,5289,3916],{"class":1306},[1050,5291,1101],{"class":1089},[1050,5293,5294],{"class":1306}," 5",[1050,5296,5280],{"class":1089},[1050,5298,5299],{"class":1265},"   # 50 requests, 5 concurrent users\n",[1050,5301,5302,5304,5306,5308,5310,5312],{"class":1052,"line":1207},[1050,5303,5270],{"class":1089},[1050,5305,1565],{"class":1306},[1050,5307,1101],{"class":1089},[1050,5309,4066],{"class":1306},[1050,5311,5280],{"class":1089},[1050,5313,5314],{"class":1265}," # 100 requests, 10 concurrent users\n",[1050,5316,5317,5319,5322,5324,5327,5329],{"class":1052,"line":1221},[1050,5318,5270],{"class":1089},[1050,5320,5321],{"class":1306},"200",[1050,5323,1101],{"class":1089},[1050,5325,5326],{"class":1306}," 20",[1050,5328,5280],{"class":1089},[1050,5330,5331],{"class":1265}," # 200 requests, 20 concurrent users\n",[1050,5333,5334,5336,5339,5341,5343,5345],{"class":1052,"line":1227},[1050,5335,5270],{"class":1089},[1050,5337,5338],{"class":1306},"500",[1050,5340,1101],{"class":1089},[1050,5342,1639],{"class":1306},[1050,5344,5280],{"class":1089},[1050,5346,5347],{"class":1265}," # 500 requests, 50 concurrent users\n",[1050,5349,5350],{"class":1052,"line":1245},[1050,5351,5352],{"class":1089},"        ]\n",[1050,5354,5355],{"class":1052,"line":1256},[1050,5356,1259],{"class":1060},[1050,5358,5359,5362,5364],{"class":1052,"line":1262},[1050,5360,5361],{"class":1060},"        results_by_load ",[1050,5363,1318],{"class":1089},[1050,5365,1285],{"class":1089},[1050,5367,5368],{"class":1052,"line":1269},[1050,5369,1259],{"class":1060},[1050,5371,5372,5374,5376,5378,5381,5383,5386],{"class":1052,"line":1288},[1050,5373,1291],{"class":1056},[1050,5375,2353],{"class":1060},[1050,5377,1101],{"class":1089},[1050,5379,5380],{"class":1060}," concurrent_users ",[1050,5382,1297],{"class":1056},[1050,5384,5385],{"class":1060}," load_levels",[1050,5387,1847],{"class":1089},[1050,5389,5390,5393,5395,5397,5400,5402,5404,5406,5409,5411,5413,5415,5418],{"class":1052,"line":1312},[1050,5391,5392],{"class":1300},"            print",[1050,5394,1197],{"class":1089},[1050,5396,1347],{"class":1189},[1050,5398,5399],{"class":1350},"\"Testing load: ",[1050,5401,1355],{"class":1354},[1050,5403,2673],{"class":1331},[1050,5405,1361],{"class":1354},[1050,5407,5408],{"class":1350}," requests, ",[1050,5410,1355],{"class":1354},[1050,5412,2616],{"class":1331},[1050,5414,1361],{"class":1354},[1050,5416,5417],{"class":1350}," concurrent users\"",[1050,5419,1436],{"class":1089},[1050,5421,5422],{"class":1052,"line":1338},[1050,5423,2034],{"class":1060},[1050,5425,5426,5428,5430,5432,5434,5436],{"class":1052,"line":1370},[1050,5427,4659],{"class":1060},[1050,5429,1318],{"class":1089},[1050,5431,2481],{"class":1272},[1050,5433,1090],{"class":1089},[1050,5435,3887],{"class":1331},[1050,5437,1335],{"class":1089},[1050,5439,5440,5442,5444,5446,5448,5450],{"class":1052,"line":1393},[1050,5441,4675],{"class":1341},[1050,5443,1318],{"class":1089},[1050,5445,1364],{"class":1401},[1050,5447,4292],{"class":1350},[1050,5449,1364],{"class":1401},[1050,5451,1367],{"class":1089},[1050,5453,5454,5456,5458,5460],{"class":1052,"line":1410},[1050,5455,4687],{"class":1341},[1050,5457,1318],{"class":1089},[1050,5459,2673],{"class":1331},[1050,5461,1367],{"class":1089},[1050,5463,5464,5466,5468],{"class":1052,"line":1416},[1050,5465,4700],{"class":1341},[1050,5467,1318],{"class":1089},[1050,5469,5470],{"class":1331},"concurrent_users\n",[1050,5472,5473],{"class":1052,"line":1439},[1050,5474,1413],{"class":1089},[1050,5476,5477],{"class":1052,"line":1444},[1050,5478,2034],{"class":1060},[1050,5480,5481,5484,5486,5488,5491,5493,5495,5497,5500,5502,5504,5506],{"class":1052,"line":1450},[1050,5482,5483],{"class":1060},"            results",[1050,5485,1661],{"class":1089},[1050,5487,1364],{"class":1401},[1050,5489,5490],{"class":1350},"load_level",[1050,5492,1364],{"class":1401},[1050,5494,3020],{"class":1089},[1050,5496,1282],{"class":1089},[1050,5498,5499],{"class":1089}," (",[1050,5501,2673],{"class":1060},[1050,5503,1101],{"class":1089},[1050,5505,2362],{"class":1060},[1050,5507,1436],{"class":1089},[1050,5509,5510,5513,5515,5517,5519,5521],{"class":1052,"line":1473},[1050,5511,5512],{"class":1060},"            results_by_load",[1050,5514,1090],{"class":1089},[1050,5516,1428],{"class":1331},[1050,5518,1197],{"class":1089},[1050,5520,2906],{"class":1331},[1050,5522,1436],{"class":1089},[1050,5524,5525],{"class":1052,"line":1527},[1050,5526,2034],{"class":1060},[1050,5528,5529,5531,5533,5535,5537,5539,5541,5543,5545,5547,5549,5551,5553,5555],{"class":1052,"line":1532},[1050,5530,5392],{"class":1300},[1050,5532,1197],{"class":1089},[1050,5534,1347],{"class":1189},[1050,5536,4103],{"class":1350},[1050,5538,1355],{"class":1354},[1050,5540,2906],{"class":1331},[1050,5542,1661],{"class":1089},[1050,5544,1364],{"class":1401},[1050,5546,3197],{"class":1350},[1050,5548,1364],{"class":1401},[1050,5550,3020],{"class":1089},[1050,5552,4120],{"class":1189},[1050,5554,1361],{"class":1354},[1050,5556,5557],{"class":1350},"%, \"\n",[1050,5559,5560,5563,5566,5568,5570,5572,5574,5576,5578,5580,5582,5584,5586],{"class":1052,"line":1538},[1050,5561,5562],{"class":1189},"                  f",[1050,5564,5565],{"class":1350},"\"Avg Response Time: ",[1050,5567,1355],{"class":1354},[1050,5569,2906],{"class":1331},[1050,5571,1661],{"class":1089},[1050,5573,1364],{"class":1401},[1050,5575,3246],{"class":1350},[1050,5577,1364],{"class":1401},[1050,5579,3020],{"class":1089},[1050,5581,4156],{"class":1189},[1050,5583,1361],{"class":1354},[1050,5585,4161],{"class":1350},[1050,5587,1436],{"class":1089},[1050,5589,5590],{"class":1052,"line":1552},[1050,5591,2034],{"class":1060},[1050,5593,5594],{"class":1052,"line":1570},[1050,5595,5596],{"class":1265},"            # Stop if success rate drops below threshold\n",[1050,5598,5599,5601,5603,5605,5607,5609,5611,5613,5615,5618],{"class":1052,"line":1590},[1050,5600,1906],{"class":1056},[1050,5602,2930],{"class":1060},[1050,5604,1661],{"class":1089},[1050,5606,1364],{"class":1401},[1050,5608,3197],{"class":1350},[1050,5610,1364],{"class":1401},[1050,5612,3020],{"class":1089},[1050,5614,2137],{"class":1635},[1050,5616,5617],{"class":1306}," 80.0",[1050,5619,1847],{"class":1089},[1050,5621,5622,5625,5627,5629,5632,5634,5636,5638,5640,5642,5644,5646,5649],{"class":1052,"line":1613},[1050,5623,5624],{"class":1300},"                print",[1050,5626,1197],{"class":1089},[1050,5628,1347],{"class":1189},[1050,5630,5631],{"class":1350},"\"Breaking point reached at ",[1050,5633,1355],{"class":1354},[1050,5635,2673],{"class":1331},[1050,5637,1361],{"class":1354},[1050,5639,5408],{"class":1350},[1050,5641,1355],{"class":1354},[1050,5643,2616],{"class":1331},[1050,5645,1361],{"class":1354},[1050,5647,5648],{"class":1350}," users\"",[1050,5650,1436],{"class":1089},[1050,5652,5653],{"class":1052,"line":1647},[1050,5654,5655],{"class":1056},"                break\n",[1050,5657,5658],{"class":1052,"line":1684},[1050,5659,2034],{"class":1060},[1050,5661,5662],{"class":1052,"line":1700},[1050,5663,5664],{"class":1265},"            # Brief pause between load levels\n",[1050,5666,5667,5670,5672,5675,5677,5680],{"class":1052,"line":1715},[1050,5668,5669],{"class":1060},"            time",[1050,5671,1090],{"class":1089},[1050,5673,5674],{"class":1331},"sleep",[1050,5676,1197],{"class":1089},[1050,5678,5679],{"class":1306},"2",[1050,5681,1436],{"class":1089},[1050,5683,5684],{"class":1052,"line":1720},[1050,5685,1259],{"class":1060},[1050,5687,5688],{"class":1052,"line":1740},[1050,5689,5690],{"class":1265},"        # Analyze degradation pattern\n",[1050,5692,5693,5695,5697,5700,5702,5705],{"class":1052,"line":1745},[1050,5694,1273],{"class":1272},[1050,5696,1090],{"class":1089},[1050,5698,5699],{"class":1331},"analyze_performance_degradation",[1050,5701,1197],{"class":1089},[1050,5703,5704],{"class":1331},"results_by_load",[1050,5706,1436],{"class":1089},[1050,5708,5709],{"class":1052,"line":1799},[1050,5710,1224],{"class":1060},[1050,5712,5713,5715,5718,5720,5722,5724,5727],{"class":1052,"line":1809},[1050,5714,1230],{"class":1189},[1050,5716,5717],{"class":1233}," analyze_performance_degradation",[1050,5719,1197],{"class":1089},[1050,5721,1240],{"class":1239},[1050,5723,1101],{"class":1089},[1050,5725,5726],{"class":1759}," results_by_load",[1050,5728,1204],{"class":1089},[1050,5730,5731,5733,5736],{"class":1052,"line":1814},[1050,5732,1248],{"class":1210},[1050,5734,5735],{"class":1214},"Analyze how performance degrades with increased load",[1050,5737,1218],{"class":1210},[1050,5739,5740],{"class":1052,"line":1828},[1050,5741,1259],{"class":1060},[1050,5743,5744,5746,5748,5750,5753,5756,5758],{"class":1052,"line":1833},[1050,5745,4082],{"class":1300},[1050,5747,1197],{"class":1089},[1050,5749,2026],{"class":1401},[1050,5751,5752],{"class":1272},"\\n",[1050,5754,5755],{"class":1350},"Performance Degradation Analysis:",[1050,5757,2026],{"class":1401},[1050,5759,1436],{"class":1089},[1050,5761,5762,5764,5766,5768,5771,5774,5777,5780,5783,5785,5788,5790],{"class":1052,"line":1839},[1050,5763,4082],{"class":1300},[1050,5765,1197],{"class":1089},[1050,5767,2026],{"class":1401},[1050,5769,5770],{"class":1350},"Load Level",[1050,5772,5773],{"class":1272},"\\t\\t",[1050,5775,5776],{"class":1350},"Success Rate",[1050,5778,5779],{"class":1272},"\\t",[1050,5781,5782],{"class":1350},"Avg Response Time",[1050,5784,5779],{"class":1272},[1050,5786,5787],{"class":1350},"P95 Response Time",[1050,5789,2026],{"class":1401},[1050,5791,1436],{"class":1089},[1050,5793,5794,5796,5798,5800,5802,5804,5806,5809],{"class":1052,"line":1850},[1050,5795,4082],{"class":1300},[1050,5797,1197],{"class":1089},[1050,5799,2026],{"class":1401},[1050,5801,2105],{"class":1350},[1050,5803,2026],{"class":1401},[1050,5805,1636],{"class":1635},[1050,5807,5808],{"class":1306}," 80",[1050,5810,1436],{"class":1089},[1050,5812,5813],{"class":1052,"line":1867},[1050,5814,1259],{"class":1060},[1050,5816,5817,5819,5821,5823,5825],{"class":1052,"line":1872},[1050,5818,1291],{"class":1056},[1050,5820,3054],{"class":1060},[1050,5822,1297],{"class":1056},[1050,5824,5726],{"class":1060},[1050,5826,1847],{"class":1089},[1050,5828,5829,5832,5834,5836,5838,5840,5842,5844],{"class":1052,"line":1890},[1050,5830,5831],{"class":1060},"            load ",[1050,5833,1318],{"class":1089},[1050,5835,2930],{"class":1060},[1050,5837,1661],{"class":1089},[1050,5839,1364],{"class":1401},[1050,5841,5490],{"class":1350},[1050,5843,1364],{"class":1401},[1050,5845,2552],{"class":1089},[1050,5847,5848,5850,5852,5854,5856,5858,5861,5863,5866,5868,5871,5873,5876,5878,5880,5882,5885,5887,5890,5892,5895,5897],{"class":1052,"line":1895},[1050,5849,5392],{"class":1300},[1050,5851,1197],{"class":1089},[1050,5853,1347],{"class":1189},[1050,5855,2026],{"class":1350},[1050,5857,1355],{"class":1354},[1050,5859,5860],{"class":1331},"load",[1050,5862,1661],{"class":1089},[1050,5864,5865],{"class":1306},"0",[1050,5867,3020],{"class":1089},[1050,5869,5870],{"class":1189},":3d",[1050,5872,1361],{"class":1354},[1050,5874,5875],{"class":1350}," req, ",[1050,5877,1355],{"class":1354},[1050,5879,5860],{"class":1331},[1050,5881,1661],{"class":1089},[1050,5883,5884],{"class":1306},"1",[1050,5886,3020],{"class":1089},[1050,5888,5889],{"class":1189},":2d",[1050,5891,1361],{"class":1354},[1050,5893,5894],{"class":1350}," users",[1050,5896,5779],{"class":1272},[1050,5898,2877],{"class":1350},[1050,5900,5901,5903,5905,5907,5909,5911,5913,5915,5917,5919,5922,5924,5926,5928],{"class":1052,"line":1903},[1050,5902,5562],{"class":1189},[1050,5904,2026],{"class":1350},[1050,5906,1355],{"class":1354},[1050,5908,2906],{"class":1331},[1050,5910,1661],{"class":1089},[1050,5912,1364],{"class":1401},[1050,5914,3197],{"class":1350},[1050,5916,1364],{"class":1401},[1050,5918,3020],{"class":1089},[1050,5920,5921],{"class":1189},":6.1f",[1050,5923,1361],{"class":1354},[1050,5925,1667],{"class":1350},[1050,5927,5773],{"class":1272},[1050,5929,2877],{"class":1350},[1050,5931,5932,5934,5936,5938,5940,5942,5944,5946,5948,5950,5953,5955,5958,5960],{"class":1052,"line":1924},[1050,5933,5562],{"class":1189},[1050,5935,2026],{"class":1350},[1050,5937,1355],{"class":1354},[1050,5939,2906],{"class":1331},[1050,5941,1661],{"class":1089},[1050,5943,1364],{"class":1401},[1050,5945,3246],{"class":1350},[1050,5947,1364],{"class":1401},[1050,5949,3020],{"class":1089},[1050,5951,5952],{"class":1189},":8.3f",[1050,5954,1361],{"class":1354},[1050,5956,5957],{"class":1350},"s",[1050,5959,5773],{"class":1272},[1050,5961,2877],{"class":1350},[1050,5963,5964,5966,5968,5970,5972,5974,5976,5978,5980,5982,5984,5986,5988],{"class":1052,"line":1947},[1050,5965,5562],{"class":1189},[1050,5967,2026],{"class":1350},[1050,5969,1355],{"class":1354},[1050,5971,2906],{"class":1331},[1050,5973,1661],{"class":1089},[1050,5975,1364],{"class":1401},[1050,5977,3351],{"class":1350},[1050,5979,1364],{"class":1401},[1050,5981,3020],{"class":1089},[1050,5983,5952],{"class":1189},[1050,5985,1361],{"class":1354},[1050,5987,4161],{"class":1350},[1050,5989,1436],{"class":1089},[1050,5991,5992],{"class":1052,"line":1966},[1050,5993,1259],{"class":1060},[1050,5995,5996],{"class":1052,"line":1994},[1050,5997,5998],{"class":1265},"        # Check for acceptable degradation\n",[1050,6000,6001,6003,6005,6007,6009,6011,6014,6016],{"class":1052,"line":2002},[1050,6002,1842],{"class":1056},[1050,6004,1670],{"class":1300},[1050,6006,1197],{"class":1089},[1050,6008,5704],{"class":1331},[1050,6010,2619],{"class":1089},[1050,6012,6013],{"class":1635}," >=",[1050,6015,5277],{"class":1306},[1050,6017,1847],{"class":1089},[1050,6019,6020,6023,6025,6027,6029,6031],{"class":1052,"line":2031},[1050,6021,6022],{"class":1060},"            first_result ",[1050,6024,1318],{"class":1089},[1050,6026,5726],{"class":1060},[1050,6028,1661],{"class":1089},[1050,6030,5865],{"class":1306},[1050,6032,2552],{"class":1089},[1050,6034,6035,6038,6040,6042,6044,6046,6048],{"class":1052,"line":2037},[1050,6036,6037],{"class":1060},"            last_result ",[1050,6039,1318],{"class":1089},[1050,6041,5726],{"class":1060},[1050,6043,1661],{"class":1089},[1050,6045,2105],{"class":1635},[1050,6047,5884],{"class":1306},[1050,6049,2552],{"class":1089},[1050,6051,6052],{"class":1052,"line":2053},[1050,6053,2034],{"class":1060},[1050,6055,6056,6059,6061],{"class":1052,"line":2058},[1050,6057,6058],{"class":1060},"            response_time_increase ",[1050,6060,1318],{"class":1089},[1050,6062,6063],{"class":1089}," (\n",[1050,6065,6066,6069,6071,6073,6075,6077,6079,6081,6084,6086,6088,6090,6092],{"class":1052,"line":2067},[1050,6067,6068],{"class":1060},"                last_result",[1050,6070,1661],{"class":1089},[1050,6072,1364],{"class":1401},[1050,6074,3246],{"class":1350},[1050,6076,1364],{"class":1401},[1050,6078,3020],{"class":1089},[1050,6080,3212],{"class":1635},[1050,6082,6083],{"class":1060}," first_result",[1050,6085,1661],{"class":1089},[1050,6087,1364],{"class":1401},[1050,6089,3246],{"class":1350},[1050,6091,1364],{"class":1401},[1050,6093,2552],{"class":1089},[1050,6095,6096],{"class":1052,"line":2090},[1050,6097,1413],{"class":1089},[1050,6099,6100],{"class":1052,"line":2113},[1050,6101,2034],{"class":1060},[1050,6103,6104],{"class":1052,"line":2145},[1050,6105,6106],{"class":1265},"            # Response time shouldn't increase more than 3x under reasonable load\n",[1050,6108,6109,6111,6114,6117,6119],{"class":1052,"line":2172},[1050,6110,1906],{"class":1056},[1050,6112,6113],{"class":1060}," response_time_increase ",[1050,6115,6116],{"class":1635},">",[1050,6118,4387],{"class":1306},[1050,6120,1847],{"class":1089},[1050,6122,6123,6125,6127,6129,6132,6134,6137,6139,6141,6144],{"class":1052,"line":2187},[1050,6124,5624],{"class":1300},[1050,6126,1197],{"class":1089},[1050,6128,1347],{"class":1189},[1050,6130,6131],{"class":1350},"\"WARNING: Response time increased ",[1050,6133,1355],{"class":1354},[1050,6135,6136],{"class":1331},"response_time_increase",[1050,6138,4120],{"class":1189},[1050,6140,1361],{"class":1354},[1050,6142,6143],{"class":1350},"x under load\"",[1050,6145,1436],{"class":1089},[1050,6147,6148],{"class":1052,"line":2193},[1050,6149,1224],{"class":1060},[1050,6151,6152,6154,6157,6159,6161],{"class":1052,"line":2198},[1050,6153,1230],{"class":1189},[1050,6155,6156],{"class":1233}," test_memory_stress",[1050,6158,1197],{"class":1089},[1050,6160,1240],{"class":1239},[1050,6162,1204],{"class":1089},[1050,6164,6165,6167,6170],{"class":1052,"line":2215},[1050,6166,1248],{"class":1210},[1050,6168,6169],{"class":1214},"Test memory usage under stress",[1050,6171,1218],{"class":1210},[1050,6173,6174],{"class":1052,"line":2230},[1050,6175,1259],{"class":1060},[1050,6177,6178,6181],{"class":1052,"line":2237},[1050,6179,6180],{"class":1056},"        import",[1050,6182,6183],{"class":1060}," psutil\n",[1050,6185,6186,6188],{"class":1052,"line":2253},[1050,6187,6180],{"class":1056},[1050,6189,6190],{"class":1060}," os\n",[1050,6192,6193],{"class":1052,"line":2272},[1050,6194,1259],{"class":1060},[1050,6196,6197,6200,6202,6205,6207,6210,6212,6215,6217,6220],{"class":1052,"line":2288},[1050,6198,6199],{"class":1060},"        process ",[1050,6201,1318],{"class":1089},[1050,6203,6204],{"class":1060}," psutil",[1050,6206,1090],{"class":1089},[1050,6208,6209],{"class":1331},"Process",[1050,6211,1197],{"class":1089},[1050,6213,6214],{"class":1331},"os",[1050,6216,1090],{"class":1089},[1050,6218,6219],{"class":1331},"getpid",[1050,6221,6222],{"class":1089},"())\n",[1050,6224,6225],{"class":1052,"line":2304},[1050,6226,1259],{"class":1060},[1050,6228,6229],{"class":1052,"line":2325},[1050,6230,6231],{"class":1265},"        # Measure initial memory\n",[1050,6233,6234,6237,6239,6242,6244,6247,6249,6252,6254,6257,6259,6261],{"class":1052,"line":2330},[1050,6235,6236],{"class":1060},"        initial_memory ",[1050,6238,1318],{"class":1089},[1050,6240,6241],{"class":1060}," process",[1050,6243,1090],{"class":1089},[1050,6245,6246],{"class":1331},"memory_info",[1050,6248,2512],{"class":1089},[1050,6250,6251],{"class":1278},"rss",[1050,6253,3212],{"class":1635},[1050,6255,6256],{"class":1306}," 1024",[1050,6258,3212],{"class":1635},[1050,6260,6256],{"class":1306},[1050,6262,6263],{"class":1265},"  # MB\n",[1050,6265,6266],{"class":1052,"line":2335},[1050,6267,1259],{"class":1060},[1050,6269,6270],{"class":1052,"line":2374},[1050,6271,6272],{"class":1265},"        # Run memory-intensive operations\n",[1050,6274,6275,6277,6279,6281,6283,6285],{"class":1052,"line":2408},[1050,6276,2426],{"class":1060},[1050,6278,1318],{"class":1089},[1050,6280,2481],{"class":1272},[1050,6282,1090],{"class":1089},[1050,6284,3887],{"class":1331},[1050,6286,1335],{"class":1089},[1050,6288,6289,6291,6293,6295,6297,6299],{"class":1052,"line":2418},[1050,6290,3895],{"class":1341},[1050,6292,1318],{"class":1089},[1050,6294,1364],{"class":1401},[1050,6296,4292],{"class":1350},[1050,6298,1364],{"class":1401},[1050,6300,1367],{"class":1089},[1050,6302,6303,6305,6307,6309],{"class":1052,"line":2423},[1050,6304,3911],{"class":1341},[1050,6306,1318],{"class":1089},[1050,6308,5321],{"class":1306},[1050,6310,1367],{"class":1089},[1050,6312,6313,6315,6317],{"class":1052,"line":2433},[1050,6314,3924],{"class":1341},[1050,6316,1318],{"class":1089},[1050,6318,6319],{"class":1306},"20\n",[1050,6321,6322],{"class":1052,"line":2438},[1050,6323,3935],{"class":1089},[1050,6325,6326],{"class":1052,"line":2450},[1050,6327,1259],{"class":1060},[1050,6329,6330],{"class":1052,"line":2461},[1050,6331,6332],{"class":1265},"        # Measure final memory\n",[1050,6334,6335,6338,6340,6342,6344,6346,6348,6350,6352,6354,6356,6358],{"class":1052,"line":2470},[1050,6336,6337],{"class":1060},"        final_memory ",[1050,6339,1318],{"class":1089},[1050,6341,6241],{"class":1060},[1050,6343,1090],{"class":1089},[1050,6345,6246],{"class":1331},[1050,6347,2512],{"class":1089},[1050,6349,6251],{"class":1278},[1050,6351,3212],{"class":1635},[1050,6353,6256],{"class":1306},[1050,6355,3212],{"class":1635},[1050,6357,6256],{"class":1306},[1050,6359,6263],{"class":1265},[1050,6361,6362,6365,6367,6370,6372],{"class":1052,"line":2490},[1050,6363,6364],{"class":1060},"        memory_increase ",[1050,6366,1318],{"class":1089},[1050,6368,6369],{"class":1060}," final_memory ",[1050,6371,2105],{"class":1635},[1050,6373,6374],{"class":1060}," initial_memory\n",[1050,6376,6377],{"class":1052,"line":2496},[1050,6378,1259],{"class":1060},[1050,6380,6381,6383,6385,6387,6390],{"class":1052,"line":2533},[1050,6382,4082],{"class":1300},[1050,6384,1197],{"class":1089},[1050,6386,1347],{"class":1189},[1050,6388,6389],{"class":1350},"\"Memory Stress Test Results:\"",[1050,6391,1436],{"class":1089},[1050,6393,6394,6396,6398,6400,6403,6405,6408,6410,6412,6415],{"class":1052,"line":2555},[1050,6395,4082],{"class":1300},[1050,6397,1197],{"class":1089},[1050,6399,1347],{"class":1189},[1050,6401,6402],{"class":1350},"\"Initial Memory: ",[1050,6404,1355],{"class":1354},[1050,6406,6407],{"class":1331},"initial_memory",[1050,6409,4120],{"class":1189},[1050,6411,1361],{"class":1354},[1050,6413,6414],{"class":1350}," MB\"",[1050,6416,1436],{"class":1089},[1050,6418,6419,6421,6423,6425,6428,6430,6433,6435,6437,6439],{"class":1052,"line":2560},[1050,6420,4082],{"class":1300},[1050,6422,1197],{"class":1089},[1050,6424,1347],{"class":1189},[1050,6426,6427],{"class":1350},"\"Final Memory: ",[1050,6429,1355],{"class":1354},[1050,6431,6432],{"class":1331},"final_memory",[1050,6434,4120],{"class":1189},[1050,6436,1361],{"class":1354},[1050,6438,6414],{"class":1350},[1050,6440,1436],{"class":1089},[1050,6442,6443,6445,6447,6449,6452,6454,6457,6459,6461,6463],{"class":1052,"line":2590},[1050,6444,4082],{"class":1300},[1050,6446,1197],{"class":1089},[1050,6448,1347],{"class":1189},[1050,6450,6451],{"class":1350},"\"Memory Increase: ",[1050,6453,1355],{"class":1354},[1050,6455,6456],{"class":1331},"memory_increase",[1050,6458,4120],{"class":1189},[1050,6460,1361],{"class":1354},[1050,6462,6414],{"class":1350},[1050,6464,1436],{"class":1089},[1050,6466,6467,6469,6471,6473,6475,6477,6479,6481,6483,6485,6487,6489,6491,6493,6495],{"class":1052,"line":2595},[1050,6468,4082],{"class":1300},[1050,6470,1197],{"class":1089},[1050,6472,1347],{"class":1189},[1050,6474,4103],{"class":1350},[1050,6476,1355],{"class":1354},[1050,6478,2906],{"class":1331},[1050,6480,1661],{"class":1089},[1050,6482,1364],{"class":1401},[1050,6484,3197],{"class":1350},[1050,6486,1364],{"class":1401},[1050,6488,3020],{"class":1089},[1050,6490,4120],{"class":1189},[1050,6492,1361],{"class":1354},[1050,6494,4125],{"class":1350},[1050,6496,1436],{"class":1089},[1050,6498,6499],{"class":1052,"line":2601},[1050,6500,1259],{"class":1060},[1050,6502,6503],{"class":1052,"line":2629},[1050,6504,6505],{"class":1265},"        # Memory increase should be reasonable\n",[1050,6507,6508,6510,6512,6514,6516,6518,6520,6522,6524,6526,6529,6531,6533,6535,6537,6539],{"class":1052,"line":2635},[1050,6509,1273],{"class":1272},[1050,6511,1090],{"class":1089},[1050,6513,3986],{"class":1331},[1050,6515,1197],{"class":1089},[1050,6517,6456],{"class":1331},[1050,6519,1101],{"class":1089},[1050,6521,2125],{"class":1306},[1050,6523,1101],{"class":1089},[1050,6525,2865],{"class":1189},[1050,6527,6528],{"class":1350},"\"Memory increased by ",[1050,6530,1355],{"class":1354},[1050,6532,6456],{"class":1331},[1050,6534,4120],{"class":1189},[1050,6536,1361],{"class":1354},[1050,6538,6414],{"class":1350},[1050,6540,1436],{"class":1089},[1050,6542,6543,6545,6547,6549,6551,6553,6555,6557,6559,6561,6563,6566],{"class":1052,"line":2679},[1050,6544,1273],{"class":1272},[1050,6546,1090],{"class":1089},[1050,6548,3956],{"class":1331},[1050,6550,1197],{"class":1089},[1050,6552,2906],{"class":1331},[1050,6554,1661],{"class":1089},[1050,6556,1364],{"class":1401},[1050,6558,3197],{"class":1350},[1050,6560,1364],{"class":1401},[1050,6562,3971],{"class":1089},[1050,6564,6565],{"class":1306}," 85.0",[1050,6567,1436],{"class":1089},[1050,6569,6570],{"class":1052,"line":2684},[1050,6571,1224],{"class":1060},[1050,6573,6574,6576,6579,6581,6583],{"class":1052,"line":2690},[1050,6575,1230],{"class":1189},[1050,6577,6578],{"class":1233}," test_database_connection_stress",[1050,6580,1197],{"class":1089},[1050,6582,1240],{"class":1239},[1050,6584,1204],{"class":1089},[1050,6586,6587,6589,6592],{"class":1052,"line":2711},[1050,6588,1248],{"class":1210},[1050,6590,6591],{"class":1214},"Test database connection handling under stress",[1050,6593,1218],{"class":1210},[1050,6595,6596],{"class":1052,"line":2719},[1050,6597,1259],{"class":1060},[1050,6599,6600,6602,6604,6606,6609,6611],{"class":1052,"line":2750},[1050,6601,1453],{"class":1056},[1050,6603,1112],{"class":1060},[1050,6605,1090],{"class":1089},[1050,6607,6608],{"class":1060},"db ",[1050,6610,1057],{"class":1056},[1050,6612,6613],{"class":1060}," connections\n",[1050,6615,6616,6618,6620,6622,6624,6626,6628,6630],{"class":1052,"line":2766},[1050,6617,1453],{"class":1056},[1050,6619,1112],{"class":1060},[1050,6621,1090],{"class":1089},[1050,6623,1139],{"class":1060},[1050,6625,1090],{"class":1089},[1050,6627,1144],{"class":1060},[1050,6629,1057],{"class":1056},[1050,6631,1149],{"class":1060},[1050,6633,6634],{"class":1052,"line":2780},[1050,6635,1259],{"class":1060},[1050,6637,6638],{"class":1052,"line":2792},[1050,6639,6640],{"class":1265},"        # Test with limited database connections\n",[1050,6642,6643,6645,6648],{"class":1052,"line":2808},[1050,6644,2604],{"class":1056},[1050,6646,6647],{"class":1331}," override_settings",[1050,6649,1335],{"class":1089},[1050,6651,6652,6655],{"class":1052,"line":2824},[1050,6653,6654],{"class":1341},"            DATABASES",[1050,6656,6657],{"class":1089},"={\n",[1050,6659,6660,6662,6665,6667,6669],{"class":1052,"line":2839},[1050,6661,2070],{"class":1401},[1050,6663,6664],{"class":1350},"default",[1050,6666,1364],{"class":1401},[1050,6668,2078],{"class":1089},[1050,6670,2064],{"class":1089},[1050,6672,6673,6676,6679,6681,6683,6685,6687,6690,6693],{"class":1052,"line":2854},[1050,6674,6675],{"class":1635},"                    **",[1050,6677,6678],{"class":1331},"connections",[1050,6680,1661],{"class":1089},[1050,6682,1364],{"class":1401},[1050,6684,6664],{"class":1350},[1050,6686,1364],{"class":1401},[1050,6688,6689],{"class":1089},"].",[1050,6691,6692],{"class":1278},"settings_dict",[1050,6694,1367],{"class":1089},[1050,6696,6697,6700,6703,6705,6707],{"class":1052,"line":2880},[1050,6698,6699],{"class":1401},"                    '",[1050,6701,6702],{"class":1350},"OPTIONS",[1050,6704,1364],{"class":1401},[1050,6706,2078],{"class":1089},[1050,6708,2064],{"class":1089},[1050,6710,6711,6713,6716,6718,6720,6722,6724],{"class":1052,"line":2886},[1050,6712,2795],{"class":1401},[1050,6714,6715],{"class":1350},"MAX_CONNS",[1050,6717,1364],{"class":1401},[1050,6719,2078],{"class":1089},[1050,6721,4066],{"class":1306},[1050,6723,1101],{"class":1089},[1050,6725,6726],{"class":1265},"  # Limit connections\n",[1050,6728,6729],{"class":1052,"line":2891},[1050,6730,6731],{"class":1089},"                    }\n",[1050,6733,6734],{"class":1052,"line":2911},[1050,6735,6736],{"class":1089},"                }\n",[1050,6738,6739],{"class":1052,"line":2916},[1050,6740,2190],{"class":1089},[1050,6742,6743],{"class":1052,"line":2935},[1050,6744,6745],{"class":1089},"        ):\n",[1050,6747,6748,6750,6752,6754,6756,6758],{"class":1052,"line":2945},[1050,6749,4659],{"class":1060},[1050,6751,1318],{"class":1089},[1050,6753,2481],{"class":1272},[1050,6755,1090],{"class":1089},[1050,6757,3887],{"class":1331},[1050,6759,1335],{"class":1089},[1050,6761,6762,6764,6766,6768,6770,6772],{"class":1052,"line":2950},[1050,6763,4675],{"class":1341},[1050,6765,1318],{"class":1089},[1050,6767,1364],{"class":1401},[1050,6769,4292],{"class":1350},[1050,6771,1364],{"class":1401},[1050,6773,1367],{"class":1089},[1050,6775,6776,6778,6780,6782],{"class":1052,"line":2962},[1050,6777,4687],{"class":1341},[1050,6779,1318],{"class":1089},[1050,6781,1565],{"class":1306},[1050,6783,1367],{"class":1089},[1050,6785,6786,6788,6790,6793],{"class":1052,"line":2988},[1050,6787,4700],{"class":1341},[1050,6789,1318],{"class":1089},[1050,6791,6792],{"class":1306},"15",[1050,6794,6795],{"class":1265},"  # More users than DB connections\n",[1050,6797,6798],{"class":1052,"line":2993},[1050,6799,1413],{"class":1089},[1050,6801,6802],{"class":1052,"line":2999},[1050,6803,2034],{"class":1060},[1050,6805,6806,6808,6810,6812,6815],{"class":1052,"line":3034},[1050,6807,5392],{"class":1300},[1050,6809,1197],{"class":1089},[1050,6811,1347],{"class":1189},[1050,6813,6814],{"class":1350},"\"Database Connection Stress Test:\"",[1050,6816,1436],{"class":1089},[1050,6818,6819,6821,6823,6825,6827,6829,6831,6833,6835,6837,6839,6841,6843,6845,6847],{"class":1052,"line":3074},[1050,6820,5392],{"class":1300},[1050,6822,1197],{"class":1089},[1050,6824,1347],{"class":1189},[1050,6826,4103],{"class":1350},[1050,6828,1355],{"class":1354},[1050,6830,2906],{"class":1331},[1050,6832,1661],{"class":1089},[1050,6834,1364],{"class":1401},[1050,6836,3197],{"class":1350},[1050,6838,1364],{"class":1401},[1050,6840,3020],{"class":1089},[1050,6842,4120],{"class":1189},[1050,6844,1361],{"class":1354},[1050,6846,4125],{"class":1350},[1050,6848,1436],{"class":1089},[1050,6850,6851,6853,6855,6857,6859,6861,6863,6865,6867,6869,6871,6873,6875,6877],{"class":1052,"line":3110},[1050,6852,5392],{"class":1300},[1050,6854,1197],{"class":1089},[1050,6856,1347],{"class":1189},[1050,6858,4514],{"class":1350},[1050,6860,1355],{"class":1354},[1050,6862,2906],{"class":1331},[1050,6864,1661],{"class":1089},[1050,6866,1364],{"class":1401},[1050,6868,3177],{"class":1350},[1050,6870,1364],{"class":1401},[1050,6872,3020],{"class":1089},[1050,6874,1361],{"class":1354},[1050,6876,2026],{"class":1350},[1050,6878,1436],{"class":1089},[1050,6880,6881],{"class":1052,"line":3115},[1050,6882,2034],{"class":1060},[1050,6884,6885],{"class":1052,"line":3121},[1050,6886,6887],{"class":1265},"            # Should handle connection limits gracefully\n",[1050,6889,6890,6892,6894,6896,6898,6900,6902,6904,6906,6908,6910,6912],{"class":1052,"line":3131},[1050,6891,1419],{"class":1272},[1050,6893,1090],{"class":1089},[1050,6895,3956],{"class":1331},[1050,6897,1197],{"class":1089},[1050,6899,2906],{"class":1331},[1050,6901,1661],{"class":1089},[1050,6903,1364],{"class":1401},[1050,6905,3197],{"class":1350},[1050,6907,1364],{"class":1401},[1050,6909,3971],{"class":1089},[1050,6911,5617],{"class":1306},[1050,6913,1436],{"class":1089},[1030,6915,6917],{"id":6916},"database-performance-testing","Database Performance Testing",[1035,6919,6921],{"id":6920},"query-performance-analysis","Query Performance Analysis",[1040,6923,6925],{"className":1042,"code":6924,"language":1044,"meta":1045,"style":1045},"class DatabasePerformanceTests(TestCase):\n    \"\"\"Test database query performance\"\"\"\n    \n    def setUp(self):\n        \"\"\"Set up large dataset for performance testing\"\"\"\n        \n        # Create many users\n        self.users = []\n        for i in range(100):\n            user = User.objects.create_user(\n                username=f'perfuser{i}',\n                email=f'perfuser{i}@example.com',\n                password='testpass123'\n            )\n            self.users.append(user)\n        \n        # Create many categories\n        from blog.models import Category\n        self.categories = []\n        for i in range(20):\n            category = Category.objects.create(\n                name=f'Category {i}',\n                slug=f'category-{i}'\n            )\n            self.categories.append(category)\n        \n        # Create many posts\n        from blog.models import BlogPost\n        self.posts = []\n        for i in range(1000):\n            post = BlogPost.objects.create(\n                title=f'Performance Test Post {i}',\n                content=f'Content for performance test post {i}. ' * 100,\n                author=self.users[i % len(self.users)],\n                category=self.categories[i % len(self.categories)],\n                status='published'\n            )\n            self.posts.append(post)\n    \n    def test_query_performance_without_optimization(self):\n        \"\"\"Test query performance without optimization (N+1 problem)\"\"\"\n        \n        from django.test.utils import override_settings\n        from django.db import connection\n        \n        with override_settings(DEBUG=True):\n            connection.queries_log.clear()\n            \n            start_time = time.time()\n            \n            # Unoptimized query - causes N+1 problem\n            posts = BlogPost.objects.all()[:50]\n            \n            for post in posts:\n                # Each access causes additional query\n                author_name = post.author.username\n                category_name = post.category.name\n            \n            end_time = time.time()\n            \n            query_count = len(connection.queries)\n            execution_time = end_time - start_time\n            \n            print(f\"Unoptimized Query Performance:\")\n            print(f\"Queries: {query_count}\")\n            print(f\"Execution Time: {execution_time:.3f}s\")\n            \n            # Should have many queries (N+1 problem)\n            self.assertGreater(query_count, 50)\n            \n            return query_count, execution_time\n    \n    def test_query_performance_with_optimization(self):\n        \"\"\"Test query performance with optimization\"\"\"\n        \n        from django.test.utils import override_settings\n        from django.db import connection\n        \n        with override_settings(DEBUG=True):\n            connection.queries_log.clear()\n            \n            start_time = time.time()\n            \n            # Optimized query - uses select_related\n            posts = BlogPost.objects.select_related(\n                'author', 'category'\n            ).all()[:50]\n            \n            for post in posts:\n                # No additional queries needed\n                author_name = post.author.username\n                category_name = post.category.name\n            \n            end_time = time.time()\n            \n            query_count = len(connection.queries)\n            execution_time = end_time - start_time\n            \n            print(f\"Optimized Query Performance:\")\n            print(f\"Queries: {query_count}\")\n            print(f\"Execution Time: {execution_time:.3f}s\")\n            \n            # Should have minimal queries\n            self.assertLessEqual(query_count, 3)\n            \n            return query_count, execution_time\n    \n    def test_query_optimization_comparison(self):\n        \"\"\"Compare optimized vs unoptimized query performance\"\"\"\n        \n        # Test both approaches\n        unopt_queries, unopt_time = self.test_query_performance_without_optimization()\n        opt_queries, opt_time = self.test_query_performance_with_optimization()\n        \n        # Calculate improvements\n        query_reduction = (unopt_queries - opt_queries) / unopt_queries * 100\n        time_improvement = (unopt_time - opt_time) / unopt_time * 100\n        \n        print(f\"\\nOptimization Results:\")\n        print(f\"Query Reduction: {query_reduction:.1f}%\")\n        print(f\"Time Improvement: {time_improvement:.1f}%\")\n        \n        # Optimization should provide significant improvement\n        self.assertGreater(query_reduction, 80)  # At least 80% fewer queries\n        self.assertGreater(time_improvement, 50)  # At least 50% faster\n    \n    def test_bulk_operations_performance(self):\n        \"\"\"Test bulk database operations performance\"\"\"\n        \n        from django.test.utils import override_settings\n        from django.db import connection\n        \n        # Test individual creates (slow)\n        with override_settings(DEBUG=True):\n            connection.queries_log.clear()\n            \n            start_time = time.time()\n            \n            individual_posts = []\n            for i in range(100):\n                post = BlogPost.objects.create(\n                    title=f'Individual Post {i}',\n                    content=f'Content {i}',\n                    author=self.users[0],\n                    category=self.categories[0]\n                )\n                individual_posts.append(post)\n            \n            individual_time = time.time() - start_time\n            individual_queries = len(connection.queries)\n        \n        # Clean up\n        BlogPost.objects.filter(title__startswith='Individual Post').delete()\n        \n        # Test bulk create (fast)\n        with override_settings(DEBUG=True):\n            connection.queries_log.clear()\n            \n            start_time = time.time()\n            \n            bulk_posts = []\n            for i in range(100):\n                post = BlogPost(\n                    title=f'Bulk Post {i}',\n                    content=f'Content {i}',\n                    author=self.users[0],\n                    category=self.categories[0]\n                )\n                bulk_posts.append(post)\n            \n            BlogPost.objects.bulk_create(bulk_posts)\n            \n            bulk_time = time.time() - start_time\n            bulk_queries = len(connection.queries)\n        \n        print(f\"Bulk Operations Performance Comparison:\")\n        print(f\"Individual Creates: {individual_queries} queries, {individual_time:.3f}s\")\n        print(f\"Bulk Create: {bulk_queries} queries, {bulk_time:.3f}s\")\n        \n        # Bulk operations should be much more efficient\n        self.assertLess(bulk_queries, individual_queries / 10)  # At least 10x fewer queries\n        self.assertLess(bulk_time, individual_time / 5)  # At least 5x faster\n    \n    def test_pagination_performance(self):\n        \"\"\"Test pagination performance with large datasets\"\"\"\n        \n        from django.core.paginator import Paginator\n        from django.test.utils import override_settings\n        from django.db import connection\n        \n        # Test different pagination approaches\n        approaches = [\n            (\"Basic Pagination\", lambda: BlogPost.objects.all()),\n            (\"Optimized Pagination\", lambda: BlogPost.objects.select_related('author', 'category')),\n            (\"Filtered Pagination\", lambda: BlogPost.objects.filter(status='published')),\n        ]\n        \n        results = {}\n        \n        for name, queryset_func in approaches:\n            with override_settings(DEBUG=True):\n                connection.queries_log.clear()\n                \n                start_time = time.time()\n                \n                queryset = queryset_func()\n                paginator = Paginator(queryset, 20)  # 20 items per page\n                \n                # Test accessing different pages\n                page1 = paginator.page(1)\n                page5 = paginator.page(5)\n                page10 = paginator.page(10)\n                \n                # Access items to trigger queries\n                for post in page1:\n                    title = post.title\n                \n                end_time = time.time()\n                \n                results[name] = {\n                    'queries': len(connection.queries),\n                    'time': end_time - start_time\n                }\n        \n        print(f\"Pagination Performance Results:\")\n        for name, result in results.items():\n            print(f\"{name}: {result['queries']} queries, {result['time']:.3f}s\")\n        \n        # Optimized pagination should perform better\n        basic_queries = results[\"Basic Pagination\"][\"queries\"]\n        optimized_queries = results[\"Optimized Pagination\"][\"queries\"]\n        \n        self.assertLessEqual(optimized_queries, basic_queries)\n",[1047,6926,6927,6940,6949,6953,6965,6974,6978,6983,6995,7011,7029,7050,7070,7082,7086,7104,7108,7113,7127,7140,7156,7175,7197,7217,7221,7239,7243,7248,7263,7275,7292,7310,7331,7356,7386,7416,7428,7432,7450,7454,7467,7476,7480,7498,7513,7517,7535,7552,7556,7571,7575,7580,7605,7609,7622,7627,7647,7665,7669,7683,7687,7708,7722,7726,7739,7761,7785,7789,7794,7812,7816,7828,7832,7845,7854,7858,7876,7890,7894,7910,7924,7928,7942,7946,7951,7970,7986,7999,8003,8015,8020,8036,8052,8056,8070,8074,8092,8104,8108,8121,8141,8163,8167,8172,8192,8196,8206,8210,8223,8232,8236,8241,8262,8283,8287,8292,8322,8349,8353,8370,8394,8418,8422,8427,8448,8469,8473,8486,8495,8499,8517,8531,8535,8540,8556,8570,8574,8588,8592,8601,8617,8636,8658,8680,8700,8719,8724,8739,8743,8763,8782,8786,8791,8827,8831,8836,8852,8866,8870,8884,8888,8897,8913,8923,8944,8964,8982,9000,9004,9019,9023,9044,9048,9067,9086,9090,9103,9137,9170,9174,9179,9205,9231,9235,9248,9257,9261,9282,9300,9314,9318,9323,9332,9363,9409,9451,9455,9459,9467,9471,9490,9507,9522,9527,9542,9546,9558,9582,9586,9591,9612,9631,9650,9654,9659,9673,9687,9691,9706,9710,9725,9747,9763,9767,9771,9784,9805,9864,9868,9873,9901,9928,9932],{"__ignoreMap":1045},[1050,6928,6929,6931,6934,6936,6938],{"class":1052,"line":1053},[1050,6930,1190],{"class":1189},[1050,6932,6933],{"class":1193}," DatabasePerformanceTests",[1050,6935,1197],{"class":1089},[1050,6937,1201],{"class":1200},[1050,6939,1204],{"class":1089},[1050,6941,6942,6944,6947],{"class":1052,"line":1064},[1050,6943,1211],{"class":1210},[1050,6945,6946],{"class":1214},"Test database query performance",[1050,6948,1218],{"class":1210},[1050,6950,6951],{"class":1052,"line":1072},[1050,6952,1224],{"class":1060},[1050,6954,6955,6957,6959,6961,6963],{"class":1052,"line":1080},[1050,6956,1230],{"class":1189},[1050,6958,1234],{"class":1233},[1050,6960,1197],{"class":1089},[1050,6962,1240],{"class":1239},[1050,6964,1204],{"class":1089},[1050,6966,6967,6969,6972],{"class":1052,"line":1107},[1050,6968,1248],{"class":1210},[1050,6970,6971],{"class":1214},"Set up large dataset for performance testing",[1050,6973,1218],{"class":1210},[1050,6975,6976],{"class":1052,"line":1130},[1050,6977,1259],{"class":1060},[1050,6979,6980],{"class":1052,"line":1152},[1050,6981,6982],{"class":1265},"        # Create many users\n",[1050,6984,6985,6987,6989,6991,6993],{"class":1052,"line":1179},[1050,6986,1273],{"class":1272},[1050,6988,1090],{"class":1089},[1050,6990,1279],{"class":1278},[1050,6992,1282],{"class":1089},[1050,6994,1285],{"class":1089},[1050,6996,6997,6999,7001,7003,7005,7007,7009],{"class":1052,"line":1186},[1050,6998,1291],{"class":1056},[1050,7000,1294],{"class":1060},[1050,7002,1297],{"class":1056},[1050,7004,1301],{"class":1300},[1050,7006,1197],{"class":1089},[1050,7008,1565],{"class":1306},[1050,7010,1204],{"class":1089},[1050,7012,7013,7015,7017,7019,7021,7023,7025,7027],{"class":1052,"line":1207},[1050,7014,1315],{"class":1060},[1050,7016,1318],{"class":1089},[1050,7018,1321],{"class":1060},[1050,7020,1090],{"class":1089},[1050,7022,1326],{"class":1278},[1050,7024,1090],{"class":1089},[1050,7026,1332],{"class":1331},[1050,7028,1335],{"class":1089},[1050,7030,7031,7033,7035,7037,7040,7042,7044,7046,7048],{"class":1052,"line":1221},[1050,7032,1342],{"class":1341},[1050,7034,1318],{"class":1089},[1050,7036,1347],{"class":1189},[1050,7038,7039],{"class":1350},"'perfuser",[1050,7041,1355],{"class":1354},[1050,7043,1358],{"class":1331},[1050,7045,1361],{"class":1354},[1050,7047,1364],{"class":1350},[1050,7049,1367],{"class":1089},[1050,7051,7052,7054,7056,7058,7060,7062,7064,7066,7068],{"class":1052,"line":1227},[1050,7053,1373],{"class":1341},[1050,7055,1318],{"class":1089},[1050,7057,1347],{"class":1189},[1050,7059,7039],{"class":1350},[1050,7061,1355],{"class":1354},[1050,7063,1358],{"class":1331},[1050,7065,1361],{"class":1354},[1050,7067,1388],{"class":1350},[1050,7069,1367],{"class":1089},[1050,7071,7072,7074,7076,7078,7080],{"class":1052,"line":1245},[1050,7073,1396],{"class":1341},[1050,7075,1318],{"class":1089},[1050,7077,1364],{"class":1401},[1050,7079,1404],{"class":1350},[1050,7081,1407],{"class":1401},[1050,7083,7084],{"class":1052,"line":1256},[1050,7085,1413],{"class":1089},[1050,7087,7088,7090,7092,7094,7096,7098,7100,7102],{"class":1052,"line":1262},[1050,7089,1419],{"class":1272},[1050,7091,1090],{"class":1089},[1050,7093,1279],{"class":1278},[1050,7095,1090],{"class":1089},[1050,7097,1428],{"class":1331},[1050,7099,1197],{"class":1089},[1050,7101,1433],{"class":1331},[1050,7103,1436],{"class":1089},[1050,7105,7106],{"class":1052,"line":1269},[1050,7107,1259],{"class":1060},[1050,7109,7110],{"class":1052,"line":1288},[1050,7111,7112],{"class":1265},"        # Create many categories\n",[1050,7114,7115,7117,7119,7121,7123,7125],{"class":1052,"line":1312},[1050,7116,1453],{"class":1056},[1050,7118,1456],{"class":1060},[1050,7120,1090],{"class":1089},[1050,7122,1171],{"class":1060},[1050,7124,1057],{"class":1056},[1050,7126,1470],{"class":1060},[1050,7128,7129,7131,7133,7136,7138],{"class":1052,"line":1338},[1050,7130,1273],{"class":1272},[1050,7132,1090],{"class":1089},[1050,7134,7135],{"class":1278},"categories",[1050,7137,1282],{"class":1089},[1050,7139,1285],{"class":1089},[1050,7141,7142,7144,7146,7148,7150,7152,7154],{"class":1052,"line":1370},[1050,7143,1291],{"class":1056},[1050,7145,1294],{"class":1060},[1050,7147,1297],{"class":1056},[1050,7149,1301],{"class":1300},[1050,7151,1197],{"class":1089},[1050,7153,4692],{"class":1306},[1050,7155,1204],{"class":1089},[1050,7157,7158,7161,7163,7165,7167,7169,7171,7173],{"class":1052,"line":1393},[1050,7159,7160],{"class":1060},"            category ",[1050,7162,1318],{"class":1089},[1050,7164,1485],{"class":1060},[1050,7166,1090],{"class":1089},[1050,7168,1326],{"class":1278},[1050,7170,1090],{"class":1089},[1050,7172,1494],{"class":1331},[1050,7174,1335],{"class":1089},[1050,7176,7177,7180,7182,7184,7187,7189,7191,7193,7195],{"class":1052,"line":1410},[1050,7178,7179],{"class":1341},"                name",[1050,7181,1318],{"class":1089},[1050,7183,1347],{"class":1189},[1050,7185,7186],{"class":1350},"'Category ",[1050,7188,1355],{"class":1354},[1050,7190,1358],{"class":1331},[1050,7192,1361],{"class":1354},[1050,7194,1364],{"class":1350},[1050,7196,1367],{"class":1089},[1050,7198,7199,7202,7204,7206,7209,7211,7213,7215],{"class":1052,"line":1416},[1050,7200,7201],{"class":1341},"                slug",[1050,7203,1318],{"class":1089},[1050,7205,1347],{"class":1189},[1050,7207,7208],{"class":1350},"'category-",[1050,7210,1355],{"class":1354},[1050,7212,1358],{"class":1331},[1050,7214,1361],{"class":1354},[1050,7216,1407],{"class":1350},[1050,7218,7219],{"class":1052,"line":1439},[1050,7220,1413],{"class":1089},[1050,7222,7223,7225,7227,7229,7231,7233,7235,7237],{"class":1052,"line":1444},[1050,7224,1419],{"class":1272},[1050,7226,1090],{"class":1089},[1050,7228,7135],{"class":1278},[1050,7230,1090],{"class":1089},[1050,7232,1428],{"class":1331},[1050,7234,1197],{"class":1089},[1050,7236,1480],{"class":1331},[1050,7238,1436],{"class":1089},[1050,7240,7241],{"class":1052,"line":1450},[1050,7242,1259],{"class":1060},[1050,7244,7245],{"class":1052,"line":1473},[1050,7246,7247],{"class":1265},"        # Create many posts\n",[1050,7249,7250,7252,7254,7256,7258,7260],{"class":1052,"line":1527},[1050,7251,1453],{"class":1056},[1050,7253,1456],{"class":1060},[1050,7255,1090],{"class":1089},[1050,7257,1171],{"class":1060},[1050,7259,1057],{"class":1056},[1050,7261,7262],{"class":1060}," BlogPost\n",[1050,7264,7265,7267,7269,7271,7273],{"class":1052,"line":1532},[1050,7266,1273],{"class":1272},[1050,7268,1090],{"class":1089},[1050,7270,1545],{"class":1278},[1050,7272,1282],{"class":1089},[1050,7274,1285],{"class":1089},[1050,7276,7277,7279,7281,7283,7285,7287,7290],{"class":1052,"line":1538},[1050,7278,1291],{"class":1056},[1050,7280,1294],{"class":1060},[1050,7282,1297],{"class":1056},[1050,7284,1301],{"class":1300},[1050,7286,1197],{"class":1089},[1050,7288,7289],{"class":1306},"1000",[1050,7291,1204],{"class":1089},[1050,7293,7294,7296,7298,7300,7302,7304,7306,7308],{"class":1052,"line":1552},[1050,7295,1573],{"class":1060},[1050,7297,1318],{"class":1089},[1050,7299,1465],{"class":1060},[1050,7301,1090],{"class":1089},[1050,7303,1326],{"class":1278},[1050,7305,1090],{"class":1089},[1050,7307,1494],{"class":1331},[1050,7309,1335],{"class":1089},[1050,7311,7312,7314,7316,7318,7321,7323,7325,7327,7329],{"class":1052,"line":1570},[1050,7313,1593],{"class":1341},[1050,7315,1318],{"class":1089},[1050,7317,1347],{"class":1189},[1050,7319,7320],{"class":1350},"'Performance Test Post ",[1050,7322,1355],{"class":1354},[1050,7324,1358],{"class":1331},[1050,7326,1361],{"class":1354},[1050,7328,1364],{"class":1350},[1050,7330,1367],{"class":1089},[1050,7332,7333,7335,7337,7339,7342,7344,7346,7348,7350,7352,7354],{"class":1052,"line":1590},[1050,7334,1616],{"class":1341},[1050,7336,1318],{"class":1089},[1050,7338,1347],{"class":1189},[1050,7340,7341],{"class":1350},"'Content for performance test post ",[1050,7343,1355],{"class":1354},[1050,7345,1358],{"class":1331},[1050,7347,1361],{"class":1354},[1050,7349,1632],{"class":1350},[1050,7351,1636],{"class":1635},[1050,7353,3225],{"class":1306},[1050,7355,1367],{"class":1089},[1050,7357,7358,7360,7362,7364,7366,7368,7370,7372,7374,7376,7378,7380,7382,7384],{"class":1052,"line":1613},[1050,7359,1650],{"class":1341},[1050,7361,1318],{"class":1089},[1050,7363,1240],{"class":1272},[1050,7365,1090],{"class":1089},[1050,7367,1279],{"class":1278},[1050,7369,1661],{"class":1089},[1050,7371,1664],{"class":1278},[1050,7373,1667],{"class":1635},[1050,7375,1670],{"class":1300},[1050,7377,1197],{"class":1089},[1050,7379,1240],{"class":1272},[1050,7381,1090],{"class":1089},[1050,7383,1279],{"class":1278},[1050,7385,1681],{"class":1089},[1050,7387,7388,7390,7392,7394,7396,7398,7400,7402,7404,7406,7408,7410,7412,7414],{"class":1052,"line":1647},[1050,7389,1687],{"class":1341},[1050,7391,1318],{"class":1089},[1050,7393,1240],{"class":1272},[1050,7395,1090],{"class":1089},[1050,7397,7135],{"class":1278},[1050,7399,1661],{"class":1089},[1050,7401,1664],{"class":1278},[1050,7403,1667],{"class":1635},[1050,7405,1670],{"class":1300},[1050,7407,1197],{"class":1089},[1050,7409,1240],{"class":1272},[1050,7411,1090],{"class":1089},[1050,7413,7135],{"class":1278},[1050,7415,1681],{"class":1089},[1050,7417,7418,7420,7422,7424,7426],{"class":1052,"line":1684},[1050,7419,1703],{"class":1341},[1050,7421,1318],{"class":1089},[1050,7423,1364],{"class":1401},[1050,7425,1710],{"class":1350},[1050,7427,1407],{"class":1401},[1050,7429,7430],{"class":1052,"line":1700},[1050,7431,1413],{"class":1089},[1050,7433,7434,7436,7438,7440,7442,7444,7446,7448],{"class":1052,"line":1715},[1050,7435,1419],{"class":1272},[1050,7437,1090],{"class":1089},[1050,7439,1545],{"class":1278},[1050,7441,1090],{"class":1089},[1050,7443,1428],{"class":1331},[1050,7445,1197],{"class":1089},[1050,7447,1735],{"class":1331},[1050,7449,1436],{"class":1089},[1050,7451,7452],{"class":1052,"line":1720},[1050,7453,1224],{"class":1060},[1050,7455,7456,7458,7461,7463,7465],{"class":1052,"line":1740},[1050,7457,1230],{"class":1189},[1050,7459,7460],{"class":1233}," test_query_performance_without_optimization",[1050,7462,1197],{"class":1089},[1050,7464,1240],{"class":1239},[1050,7466,1204],{"class":1089},[1050,7468,7469,7471,7474],{"class":1052,"line":1745},[1050,7470,1248],{"class":1210},[1050,7472,7473],{"class":1214},"Test query performance without optimization (N+1 problem)",[1050,7475,1218],{"class":1210},[1050,7477,7478],{"class":1052,"line":1799},[1050,7479,1259],{"class":1060},[1050,7481,7482,7484,7486,7488,7490,7492,7494,7496],{"class":1052,"line":1809},[1050,7483,1453],{"class":1056},[1050,7485,1112],{"class":1060},[1050,7487,1090],{"class":1089},[1050,7489,1139],{"class":1060},[1050,7491,1090],{"class":1089},[1050,7493,1144],{"class":1060},[1050,7495,1057],{"class":1056},[1050,7497,1149],{"class":1060},[1050,7499,7500,7502,7504,7506,7508,7510],{"class":1052,"line":1814},[1050,7501,1453],{"class":1056},[1050,7503,1112],{"class":1060},[1050,7505,1090],{"class":1089},[1050,7507,6608],{"class":1060},[1050,7509,1057],{"class":1056},[1050,7511,7512],{"class":1060}," connection\n",[1050,7514,7515],{"class":1052,"line":1828},[1050,7516,1259],{"class":1060},[1050,7518,7519,7521,7523,7525,7528,7530,7533],{"class":1052,"line":1833},[1050,7520,2604],{"class":1056},[1050,7522,6647],{"class":1331},[1050,7524,1197],{"class":1089},[1050,7526,7527],{"class":1341},"DEBUG",[1050,7529,1318],{"class":1089},[1050,7531,7532],{"class":1784},"True",[1050,7534,1204],{"class":1089},[1050,7536,7537,7540,7542,7545,7547,7550],{"class":1052,"line":1839},[1050,7538,7539],{"class":1060},"            connection",[1050,7541,1090],{"class":1089},[1050,7543,7544],{"class":1278},"queries_log",[1050,7546,1090],{"class":1089},[1050,7548,7549],{"class":1331},"clear",[1050,7551,1825],{"class":1089},[1050,7553,7554],{"class":1052,"line":1850},[1050,7555,2034],{"class":1060},[1050,7557,7558,7561,7563,7565,7567,7569],{"class":1052,"line":1867},[1050,7559,7560],{"class":1060},"            start_time ",[1050,7562,1318],{"class":1089},[1050,7564,1880],{"class":1060},[1050,7566,1090],{"class":1089},[1050,7568,1885],{"class":1331},[1050,7570,1825],{"class":1089},[1050,7572,7573],{"class":1052,"line":1872},[1050,7574,2034],{"class":1060},[1050,7576,7577],{"class":1052,"line":1890},[1050,7578,7579],{"class":1265},"            # Unoptimized query - causes N+1 problem\n",[1050,7581,7582,7585,7587,7589,7591,7593,7595,7598,7601,7603],{"class":1052,"line":1895},[1050,7583,7584],{"class":1060},"            posts ",[1050,7586,1318],{"class":1089},[1050,7588,1465],{"class":1060},[1050,7590,1090],{"class":1089},[1050,7592,1326],{"class":1278},[1050,7594,1090],{"class":1089},[1050,7596,7597],{"class":1331},"all",[1050,7599,7600],{"class":1089},"()[:",[1050,7602,3916],{"class":1306},[1050,7604,2552],{"class":1089},[1050,7606,7607],{"class":1052,"line":1903},[1050,7608,2034],{"class":1060},[1050,7610,7611,7613,7615,7617,7620],{"class":1052,"line":1924},[1050,7612,2693],{"class":1056},[1050,7614,4608],{"class":1060},[1050,7616,1297],{"class":1056},[1050,7618,7619],{"class":1060}," posts",[1050,7621,1847],{"class":1089},[1050,7623,7624],{"class":1052,"line":1947},[1050,7625,7626],{"class":1265},"                # Each access causes additional query\n",[1050,7628,7629,7632,7634,7637,7639,7642,7644],{"class":1052,"line":1966},[1050,7630,7631],{"class":1060},"                author_name ",[1050,7633,1318],{"class":1089},[1050,7635,7636],{"class":1060}," post",[1050,7638,1090],{"class":1089},[1050,7640,7641],{"class":1278},"author",[1050,7643,1090],{"class":1089},[1050,7645,7646],{"class":1278},"username\n",[1050,7648,7649,7652,7654,7656,7658,7660,7662],{"class":1052,"line":1994},[1050,7650,7651],{"class":1060},"                category_name ",[1050,7653,1318],{"class":1089},[1050,7655,7636],{"class":1060},[1050,7657,1090],{"class":1089},[1050,7659,1480],{"class":1278},[1050,7661,1090],{"class":1089},[1050,7663,7664],{"class":1278},"name\n",[1050,7666,7667],{"class":1052,"line":2002},[1050,7668,2034],{"class":1060},[1050,7670,7671,7673,7675,7677,7679,7681],{"class":1052,"line":2031},[1050,7672,2040],{"class":1060},[1050,7674,1318],{"class":1089},[1050,7676,1880],{"class":1060},[1050,7678,1090],{"class":1089},[1050,7680,1885],{"class":1331},[1050,7682,1825],{"class":1089},[1050,7684,7685],{"class":1052,"line":2037},[1050,7686,2034],{"class":1060},[1050,7688,7689,7692,7694,7696,7698,7701,7703,7706],{"class":1052,"line":2053},[1050,7690,7691],{"class":1060},"            query_count ",[1050,7693,1318],{"class":1089},[1050,7695,1670],{"class":1300},[1050,7697,1197],{"class":1089},[1050,7699,7700],{"class":1331},"connection",[1050,7702,1090],{"class":1089},[1050,7704,7705],{"class":1278},"queries",[1050,7707,1436],{"class":1089},[1050,7709,7710,7713,7715,7717,7719],{"class":1052,"line":2058},[1050,7711,7712],{"class":1060},"            execution_time ",[1050,7714,1318],{"class":1089},[1050,7716,2102],{"class":1060},[1050,7718,2105],{"class":1635},[1050,7720,7721],{"class":1060}," start_time\n",[1050,7723,7724],{"class":1052,"line":2067},[1050,7725,2034],{"class":1060},[1050,7727,7728,7730,7732,7734,7737],{"class":1052,"line":2090},[1050,7729,5392],{"class":1300},[1050,7731,1197],{"class":1089},[1050,7733,1347],{"class":1189},[1050,7735,7736],{"class":1350},"\"Unoptimized Query Performance:\"",[1050,7738,1436],{"class":1089},[1050,7740,7741,7743,7745,7747,7750,7752,7755,7757,7759],{"class":1052,"line":2113},[1050,7742,5392],{"class":1300},[1050,7744,1197],{"class":1089},[1050,7746,1347],{"class":1189},[1050,7748,7749],{"class":1350},"\"Queries: ",[1050,7751,1355],{"class":1354},[1050,7753,7754],{"class":1331},"query_count",[1050,7756,1361],{"class":1354},[1050,7758,2026],{"class":1350},[1050,7760,1436],{"class":1089},[1050,7762,7763,7765,7767,7769,7772,7774,7777,7779,7781,7783],{"class":1052,"line":2145},[1050,7764,5392],{"class":1300},[1050,7766,1197],{"class":1089},[1050,7768,1347],{"class":1189},[1050,7770,7771],{"class":1350},"\"Execution Time: ",[1050,7773,1355],{"class":1354},[1050,7775,7776],{"class":1331},"execution_time",[1050,7778,4156],{"class":1189},[1050,7780,1361],{"class":1354},[1050,7782,4161],{"class":1350},[1050,7784,1436],{"class":1089},[1050,7786,7787],{"class":1052,"line":2172},[1050,7788,2034],{"class":1060},[1050,7790,7791],{"class":1052,"line":2187},[1050,7792,7793],{"class":1265},"            # Should have many queries (N+1 problem)\n",[1050,7795,7796,7798,7800,7802,7804,7806,7808,7810],{"class":1052,"line":2193},[1050,7797,1419],{"class":1272},[1050,7799,1090],{"class":1089},[1050,7801,4049],{"class":1331},[1050,7803,1197],{"class":1089},[1050,7805,7754],{"class":1331},[1050,7807,1101],{"class":1089},[1050,7809,1639],{"class":1306},[1050,7811,1436],{"class":1089},[1050,7813,7814],{"class":1052,"line":2198},[1050,7815,2034],{"class":1060},[1050,7817,7818,7820,7823,7825],{"class":1052,"line":2215},[1050,7819,2061],{"class":1056},[1050,7821,7822],{"class":1060}," query_count",[1050,7824,1101],{"class":1089},[1050,7826,7827],{"class":1060}," execution_time\n",[1050,7829,7830],{"class":1052,"line":2230},[1050,7831,1224],{"class":1060},[1050,7833,7834,7836,7839,7841,7843],{"class":1052,"line":2237},[1050,7835,1230],{"class":1189},[1050,7837,7838],{"class":1233}," test_query_performance_with_optimization",[1050,7840,1197],{"class":1089},[1050,7842,1240],{"class":1239},[1050,7844,1204],{"class":1089},[1050,7846,7847,7849,7852],{"class":1052,"line":2253},[1050,7848,1248],{"class":1210},[1050,7850,7851],{"class":1214},"Test query performance with optimization",[1050,7853,1218],{"class":1210},[1050,7855,7856],{"class":1052,"line":2272},[1050,7857,1259],{"class":1060},[1050,7859,7860,7862,7864,7866,7868,7870,7872,7874],{"class":1052,"line":2288},[1050,7861,1453],{"class":1056},[1050,7863,1112],{"class":1060},[1050,7865,1090],{"class":1089},[1050,7867,1139],{"class":1060},[1050,7869,1090],{"class":1089},[1050,7871,1144],{"class":1060},[1050,7873,1057],{"class":1056},[1050,7875,1149],{"class":1060},[1050,7877,7878,7880,7882,7884,7886,7888],{"class":1052,"line":2304},[1050,7879,1453],{"class":1056},[1050,7881,1112],{"class":1060},[1050,7883,1090],{"class":1089},[1050,7885,6608],{"class":1060},[1050,7887,1057],{"class":1056},[1050,7889,7512],{"class":1060},[1050,7891,7892],{"class":1052,"line":2325},[1050,7893,1259],{"class":1060},[1050,7895,7896,7898,7900,7902,7904,7906,7908],{"class":1052,"line":2330},[1050,7897,2604],{"class":1056},[1050,7899,6647],{"class":1331},[1050,7901,1197],{"class":1089},[1050,7903,7527],{"class":1341},[1050,7905,1318],{"class":1089},[1050,7907,7532],{"class":1784},[1050,7909,1204],{"class":1089},[1050,7911,7912,7914,7916,7918,7920,7922],{"class":1052,"line":2335},[1050,7913,7539],{"class":1060},[1050,7915,1090],{"class":1089},[1050,7917,7544],{"class":1278},[1050,7919,1090],{"class":1089},[1050,7921,7549],{"class":1331},[1050,7923,1825],{"class":1089},[1050,7925,7926],{"class":1052,"line":2374},[1050,7927,2034],{"class":1060},[1050,7929,7930,7932,7934,7936,7938,7940],{"class":1052,"line":2408},[1050,7931,7560],{"class":1060},[1050,7933,1318],{"class":1089},[1050,7935,1880],{"class":1060},[1050,7937,1090],{"class":1089},[1050,7939,1885],{"class":1331},[1050,7941,1825],{"class":1089},[1050,7943,7944],{"class":1052,"line":2418},[1050,7945,2034],{"class":1060},[1050,7947,7948],{"class":1052,"line":2423},[1050,7949,7950],{"class":1265},"            # Optimized query - uses select_related\n",[1050,7952,7953,7955,7957,7959,7961,7963,7965,7968],{"class":1052,"line":2433},[1050,7954,7584],{"class":1060},[1050,7956,1318],{"class":1089},[1050,7958,1465],{"class":1060},[1050,7960,1090],{"class":1089},[1050,7962,1326],{"class":1278},[1050,7964,1090],{"class":1089},[1050,7966,7967],{"class":1331},"select_related",[1050,7969,1335],{"class":1089},[1050,7971,7972,7974,7976,7978,7980,7982,7984],{"class":1052,"line":2438},[1050,7973,2070],{"class":1401},[1050,7975,7641],{"class":1350},[1050,7977,1364],{"class":1401},[1050,7979,1101],{"class":1089},[1050,7981,1915],{"class":1401},[1050,7983,1480],{"class":1350},[1050,7985,1407],{"class":1401},[1050,7987,7988,7991,7993,7995,7997],{"class":1052,"line":2450},[1050,7989,7990],{"class":1089},"            ).",[1050,7992,7597],{"class":1331},[1050,7994,7600],{"class":1089},[1050,7996,3916],{"class":1306},[1050,7998,2552],{"class":1089},[1050,8000,8001],{"class":1052,"line":2461},[1050,8002,2034],{"class":1060},[1050,8004,8005,8007,8009,8011,8013],{"class":1052,"line":2470},[1050,8006,2693],{"class":1056},[1050,8008,4608],{"class":1060},[1050,8010,1297],{"class":1056},[1050,8012,7619],{"class":1060},[1050,8014,1847],{"class":1089},[1050,8016,8017],{"class":1052,"line":2490},[1050,8018,8019],{"class":1265},"                # No additional queries needed\n",[1050,8021,8022,8024,8026,8028,8030,8032,8034],{"class":1052,"line":2496},[1050,8023,7631],{"class":1060},[1050,8025,1318],{"class":1089},[1050,8027,7636],{"class":1060},[1050,8029,1090],{"class":1089},[1050,8031,7641],{"class":1278},[1050,8033,1090],{"class":1089},[1050,8035,7646],{"class":1278},[1050,8037,8038,8040,8042,8044,8046,8048,8050],{"class":1052,"line":2533},[1050,8039,7651],{"class":1060},[1050,8041,1318],{"class":1089},[1050,8043,7636],{"class":1060},[1050,8045,1090],{"class":1089},[1050,8047,1480],{"class":1278},[1050,8049,1090],{"class":1089},[1050,8051,7664],{"class":1278},[1050,8053,8054],{"class":1052,"line":2555},[1050,8055,2034],{"class":1060},[1050,8057,8058,8060,8062,8064,8066,8068],{"class":1052,"line":2560},[1050,8059,2040],{"class":1060},[1050,8061,1318],{"class":1089},[1050,8063,1880],{"class":1060},[1050,8065,1090],{"class":1089},[1050,8067,1885],{"class":1331},[1050,8069,1825],{"class":1089},[1050,8071,8072],{"class":1052,"line":2590},[1050,8073,2034],{"class":1060},[1050,8075,8076,8078,8080,8082,8084,8086,8088,8090],{"class":1052,"line":2595},[1050,8077,7691],{"class":1060},[1050,8079,1318],{"class":1089},[1050,8081,1670],{"class":1300},[1050,8083,1197],{"class":1089},[1050,8085,7700],{"class":1331},[1050,8087,1090],{"class":1089},[1050,8089,7705],{"class":1278},[1050,8091,1436],{"class":1089},[1050,8093,8094,8096,8098,8100,8102],{"class":1052,"line":2601},[1050,8095,7712],{"class":1060},[1050,8097,1318],{"class":1089},[1050,8099,2102],{"class":1060},[1050,8101,2105],{"class":1635},[1050,8103,7721],{"class":1060},[1050,8105,8106],{"class":1052,"line":2629},[1050,8107,2034],{"class":1060},[1050,8109,8110,8112,8114,8116,8119],{"class":1052,"line":2635},[1050,8111,5392],{"class":1300},[1050,8113,1197],{"class":1089},[1050,8115,1347],{"class":1189},[1050,8117,8118],{"class":1350},"\"Optimized Query Performance:\"",[1050,8120,1436],{"class":1089},[1050,8122,8123,8125,8127,8129,8131,8133,8135,8137,8139],{"class":1052,"line":2679},[1050,8124,5392],{"class":1300},[1050,8126,1197],{"class":1089},[1050,8128,1347],{"class":1189},[1050,8130,7749],{"class":1350},[1050,8132,1355],{"class":1354},[1050,8134,7754],{"class":1331},[1050,8136,1361],{"class":1354},[1050,8138,2026],{"class":1350},[1050,8140,1436],{"class":1089},[1050,8142,8143,8145,8147,8149,8151,8153,8155,8157,8159,8161],{"class":1052,"line":2684},[1050,8144,5392],{"class":1300},[1050,8146,1197],{"class":1089},[1050,8148,1347],{"class":1189},[1050,8150,7771],{"class":1350},[1050,8152,1355],{"class":1354},[1050,8154,7776],{"class":1331},[1050,8156,4156],{"class":1189},[1050,8158,1361],{"class":1354},[1050,8160,4161],{"class":1350},[1050,8162,1436],{"class":1089},[1050,8164,8165],{"class":1052,"line":2690},[1050,8166,2034],{"class":1060},[1050,8168,8169],{"class":1052,"line":2711},[1050,8170,8171],{"class":1265},"            # Should have minimal queries\n",[1050,8173,8174,8176,8178,8181,8183,8185,8187,8190],{"class":1052,"line":2719},[1050,8175,1419],{"class":1272},[1050,8177,1090],{"class":1089},[1050,8179,8180],{"class":1331},"assertLessEqual",[1050,8182,1197],{"class":1089},[1050,8184,7754],{"class":1331},[1050,8186,1101],{"class":1089},[1050,8188,8189],{"class":1306}," 3",[1050,8191,1436],{"class":1089},[1050,8193,8194],{"class":1052,"line":2750},[1050,8195,2034],{"class":1060},[1050,8197,8198,8200,8202,8204],{"class":1052,"line":2766},[1050,8199,2061],{"class":1056},[1050,8201,7822],{"class":1060},[1050,8203,1101],{"class":1089},[1050,8205,7827],{"class":1060},[1050,8207,8208],{"class":1052,"line":2780},[1050,8209,1224],{"class":1060},[1050,8211,8212,8214,8217,8219,8221],{"class":1052,"line":2792},[1050,8213,1230],{"class":1189},[1050,8215,8216],{"class":1233}," test_query_optimization_comparison",[1050,8218,1197],{"class":1089},[1050,8220,1240],{"class":1239},[1050,8222,1204],{"class":1089},[1050,8224,8225,8227,8230],{"class":1052,"line":2808},[1050,8226,1248],{"class":1210},[1050,8228,8229],{"class":1214},"Compare optimized vs unoptimized query performance",[1050,8231,1218],{"class":1210},[1050,8233,8234],{"class":1052,"line":2824},[1050,8235,1259],{"class":1060},[1050,8237,8238],{"class":1052,"line":2839},[1050,8239,8240],{"class":1265},"        # Test both approaches\n",[1050,8242,8243,8246,8248,8251,8253,8255,8257,8260],{"class":1052,"line":2854},[1050,8244,8245],{"class":1060},"        unopt_queries",[1050,8247,1101],{"class":1089},[1050,8249,8250],{"class":1060}," unopt_time ",[1050,8252,1318],{"class":1089},[1050,8254,2481],{"class":1272},[1050,8256,1090],{"class":1089},[1050,8258,8259],{"class":1331},"test_query_performance_without_optimization",[1050,8261,1825],{"class":1089},[1050,8263,8264,8267,8269,8272,8274,8276,8278,8281],{"class":1052,"line":2880},[1050,8265,8266],{"class":1060},"        opt_queries",[1050,8268,1101],{"class":1089},[1050,8270,8271],{"class":1060}," opt_time ",[1050,8273,1318],{"class":1089},[1050,8275,2481],{"class":1272},[1050,8277,1090],{"class":1089},[1050,8279,8280],{"class":1331},"test_query_performance_with_optimization",[1050,8282,1825],{"class":1089},[1050,8284,8285],{"class":1052,"line":2886},[1050,8286,1259],{"class":1060},[1050,8288,8289],{"class":1052,"line":2891},[1050,8290,8291],{"class":1265},"        # Calculate improvements\n",[1050,8293,8294,8297,8299,8301,8304,8306,8309,8311,8313,8316,8319],{"class":1052,"line":2911},[1050,8295,8296],{"class":1060},"        query_reduction ",[1050,8298,1318],{"class":1089},[1050,8300,5499],{"class":1089},[1050,8302,8303],{"class":1060},"unopt_queries ",[1050,8305,2105],{"class":1635},[1050,8307,8308],{"class":1060}," opt_queries",[1050,8310,2619],{"class":1089},[1050,8312,3212],{"class":1635},[1050,8314,8315],{"class":1060}," unopt_queries ",[1050,8317,8318],{"class":1635},"*",[1050,8320,8321],{"class":1306}," 100\n",[1050,8323,8324,8327,8329,8331,8334,8336,8339,8341,8343,8345,8347],{"class":1052,"line":2916},[1050,8325,8326],{"class":1060},"        time_improvement ",[1050,8328,1318],{"class":1089},[1050,8330,5499],{"class":1089},[1050,8332,8333],{"class":1060},"unopt_time ",[1050,8335,2105],{"class":1635},[1050,8337,8338],{"class":1060}," opt_time",[1050,8340,2619],{"class":1089},[1050,8342,3212],{"class":1635},[1050,8344,8250],{"class":1060},[1050,8346,8318],{"class":1635},[1050,8348,8321],{"class":1306},[1050,8350,8351],{"class":1052,"line":2935},[1050,8352,1259],{"class":1060},[1050,8354,8355,8357,8359,8361,8363,8365,8368],{"class":1052,"line":2945},[1050,8356,4082],{"class":1300},[1050,8358,1197],{"class":1089},[1050,8360,1347],{"class":1189},[1050,8362,2026],{"class":1350},[1050,8364,5752],{"class":1272},[1050,8366,8367],{"class":1350},"Optimization Results:\"",[1050,8369,1436],{"class":1089},[1050,8371,8372,8374,8376,8378,8381,8383,8386,8388,8390,8392],{"class":1052,"line":2950},[1050,8373,4082],{"class":1300},[1050,8375,1197],{"class":1089},[1050,8377,1347],{"class":1189},[1050,8379,8380],{"class":1350},"\"Query Reduction: ",[1050,8382,1355],{"class":1354},[1050,8384,8385],{"class":1331},"query_reduction",[1050,8387,4120],{"class":1189},[1050,8389,1361],{"class":1354},[1050,8391,4125],{"class":1350},[1050,8393,1436],{"class":1089},[1050,8395,8396,8398,8400,8402,8405,8407,8410,8412,8414,8416],{"class":1052,"line":2962},[1050,8397,4082],{"class":1300},[1050,8399,1197],{"class":1089},[1050,8401,1347],{"class":1189},[1050,8403,8404],{"class":1350},"\"Time Improvement: ",[1050,8406,1355],{"class":1354},[1050,8408,8409],{"class":1331},"time_improvement",[1050,8411,4120],{"class":1189},[1050,8413,1361],{"class":1354},[1050,8415,4125],{"class":1350},[1050,8417,1436],{"class":1089},[1050,8419,8420],{"class":1052,"line":2988},[1050,8421,1259],{"class":1060},[1050,8423,8424],{"class":1052,"line":2993},[1050,8425,8426],{"class":1265},"        # Optimization should provide significant improvement\n",[1050,8428,8429,8431,8433,8435,8437,8439,8441,8443,8445],{"class":1052,"line":2999},[1050,8430,1273],{"class":1272},[1050,8432,1090],{"class":1089},[1050,8434,4049],{"class":1331},[1050,8436,1197],{"class":1089},[1050,8438,8385],{"class":1331},[1050,8440,1101],{"class":1089},[1050,8442,5808],{"class":1306},[1050,8444,2619],{"class":1089},[1050,8446,8447],{"class":1265},"  # At least 80% fewer queries\n",[1050,8449,8450,8452,8454,8456,8458,8460,8462,8464,8466],{"class":1052,"line":3034},[1050,8451,1273],{"class":1272},[1050,8453,1090],{"class":1089},[1050,8455,4049],{"class":1331},[1050,8457,1197],{"class":1089},[1050,8459,8409],{"class":1331},[1050,8461,1101],{"class":1089},[1050,8463,1639],{"class":1306},[1050,8465,2619],{"class":1089},[1050,8467,8468],{"class":1265},"  # At least 50% faster\n",[1050,8470,8471],{"class":1052,"line":3074},[1050,8472,1224],{"class":1060},[1050,8474,8475,8477,8480,8482,8484],{"class":1052,"line":3110},[1050,8476,1230],{"class":1189},[1050,8478,8479],{"class":1233}," test_bulk_operations_performance",[1050,8481,1197],{"class":1089},[1050,8483,1240],{"class":1239},[1050,8485,1204],{"class":1089},[1050,8487,8488,8490,8493],{"class":1052,"line":3115},[1050,8489,1248],{"class":1210},[1050,8491,8492],{"class":1214},"Test bulk database operations performance",[1050,8494,1218],{"class":1210},[1050,8496,8497],{"class":1052,"line":3121},[1050,8498,1259],{"class":1060},[1050,8500,8501,8503,8505,8507,8509,8511,8513,8515],{"class":1052,"line":3131},[1050,8502,1453],{"class":1056},[1050,8504,1112],{"class":1060},[1050,8506,1090],{"class":1089},[1050,8508,1139],{"class":1060},[1050,8510,1090],{"class":1089},[1050,8512,1144],{"class":1060},[1050,8514,1057],{"class":1056},[1050,8516,1149],{"class":1060},[1050,8518,8519,8521,8523,8525,8527,8529],{"class":1052,"line":3152},[1050,8520,1453],{"class":1056},[1050,8522,1112],{"class":1060},[1050,8524,1090],{"class":1089},[1050,8526,6608],{"class":1060},[1050,8528,1057],{"class":1056},[1050,8530,7512],{"class":1060},[1050,8532,8533],{"class":1052,"line":3172},[1050,8534,1259],{"class":1060},[1050,8536,8537],{"class":1052,"line":3192},[1050,8538,8539],{"class":1265},"        # Test individual creates (slow)\n",[1050,8541,8542,8544,8546,8548,8550,8552,8554],{"class":1052,"line":3230},[1050,8543,2604],{"class":1056},[1050,8545,6647],{"class":1331},[1050,8547,1197],{"class":1089},[1050,8549,7527],{"class":1341},[1050,8551,1318],{"class":1089},[1050,8553,7532],{"class":1784},[1050,8555,1204],{"class":1089},[1050,8557,8558,8560,8562,8564,8566,8568],{"class":1052,"line":3235},[1050,8559,7539],{"class":1060},[1050,8561,1090],{"class":1089},[1050,8563,7544],{"class":1278},[1050,8565,1090],{"class":1089},[1050,8567,7549],{"class":1331},[1050,8569,1825],{"class":1089},[1050,8571,8572],{"class":1052,"line":3241},[1050,8573,2034],{"class":1060},[1050,8575,8576,8578,8580,8582,8584,8586],{"class":1052,"line":3268},[1050,8577,7560],{"class":1060},[1050,8579,1318],{"class":1089},[1050,8581,1880],{"class":1060},[1050,8583,1090],{"class":1089},[1050,8585,1885],{"class":1331},[1050,8587,1825],{"class":1089},[1050,8589,8590],{"class":1052,"line":3289},[1050,8591,2034],{"class":1060},[1050,8593,8594,8597,8599],{"class":1052,"line":3310},[1050,8595,8596],{"class":1060},"            individual_posts ",[1050,8598,1318],{"class":1089},[1050,8600,1285],{"class":1089},[1050,8602,8603,8605,8607,8609,8611,8613,8615],{"class":1052,"line":3335},[1050,8604,2693],{"class":1056},[1050,8606,1294],{"class":1060},[1050,8608,1297],{"class":1056},[1050,8610,1301],{"class":1300},[1050,8612,1197],{"class":1089},[1050,8614,1565],{"class":1306},[1050,8616,1204],{"class":1089},[1050,8618,8619,8622,8624,8626,8628,8630,8632,8634],{"class":1052,"line":3340},[1050,8620,8621],{"class":1060},"                post ",[1050,8623,1318],{"class":1089},[1050,8625,1465],{"class":1060},[1050,8627,1090],{"class":1089},[1050,8629,1326],{"class":1278},[1050,8631,1090],{"class":1089},[1050,8633,1494],{"class":1331},[1050,8635,1335],{"class":1089},[1050,8637,8638,8641,8643,8645,8648,8650,8652,8654,8656],{"class":1052,"line":3346},[1050,8639,8640],{"class":1341},"                    title",[1050,8642,1318],{"class":1089},[1050,8644,1347],{"class":1189},[1050,8646,8647],{"class":1350},"'Individual Post ",[1050,8649,1355],{"class":1354},[1050,8651,1358],{"class":1331},[1050,8653,1361],{"class":1354},[1050,8655,1364],{"class":1350},[1050,8657,1367],{"class":1089},[1050,8659,8660,8663,8665,8667,8670,8672,8674,8676,8678],{"class":1052,"line":3376},[1050,8661,8662],{"class":1341},"                    content",[1050,8664,1318],{"class":1089},[1050,8666,1347],{"class":1189},[1050,8668,8669],{"class":1350},"'Content ",[1050,8671,1355],{"class":1354},[1050,8673,1358],{"class":1331},[1050,8675,1361],{"class":1354},[1050,8677,1364],{"class":1350},[1050,8679,1367],{"class":1089},[1050,8681,8682,8685,8687,8689,8691,8693,8695,8697],{"class":1052,"line":3405},[1050,8683,8684],{"class":1341},"                    author",[1050,8686,1318],{"class":1089},[1050,8688,1240],{"class":1272},[1050,8690,1090],{"class":1089},[1050,8692,1279],{"class":1278},[1050,8694,1661],{"class":1089},[1050,8696,5865],{"class":1306},[1050,8698,8699],{"class":1089},"],\n",[1050,8701,8702,8705,8707,8709,8711,8713,8715,8717],{"class":1052,"line":3410},[1050,8703,8704],{"class":1341},"                    category",[1050,8706,1318],{"class":1089},[1050,8708,1240],{"class":1272},[1050,8710,1090],{"class":1089},[1050,8712,7135],{"class":1278},[1050,8714,1661],{"class":1089},[1050,8716,5865],{"class":1306},[1050,8718,2552],{"class":1089},[1050,8720,8721],{"class":1052,"line":3416},[1050,8722,8723],{"class":1089},"                )\n",[1050,8725,8726,8729,8731,8733,8735,8737],{"class":1052,"line":3457},[1050,8727,8728],{"class":1060},"                individual_posts",[1050,8730,1090],{"class":1089},[1050,8732,1428],{"class":1331},[1050,8734,1197],{"class":1089},[1050,8736,1735],{"class":1331},[1050,8738,1436],{"class":1089},[1050,8740,8741],{"class":1052,"line":3462},[1050,8742,2034],{"class":1060},[1050,8744,8745,8748,8750,8752,8754,8756,8759,8761],{"class":1052,"line":3468},[1050,8746,8747],{"class":1060},"            individual_time ",[1050,8749,1318],{"class":1089},[1050,8751,1880],{"class":1060},[1050,8753,1090],{"class":1089},[1050,8755,1885],{"class":1331},[1050,8757,8758],{"class":1089},"()",[1050,8760,3680],{"class":1635},[1050,8762,7721],{"class":1060},[1050,8764,8765,8768,8770,8772,8774,8776,8778,8780],{"class":1052,"line":3518},[1050,8766,8767],{"class":1060},"            individual_queries ",[1050,8769,1318],{"class":1089},[1050,8771,1670],{"class":1300},[1050,8773,1197],{"class":1089},[1050,8775,7700],{"class":1331},[1050,8777,1090],{"class":1089},[1050,8779,7705],{"class":1278},[1050,8781,1436],{"class":1089},[1050,8783,8784],{"class":1052,"line":3543},[1050,8785,1259],{"class":1060},[1050,8787,8788],{"class":1052,"line":3549},[1050,8789,8790],{"class":1265},"        # Clean up\n",[1050,8792,8793,8796,8798,8800,8802,8805,8807,8810,8812,8814,8817,8819,8822,8825],{"class":1052,"line":3554},[1050,8794,8795],{"class":1060},"        BlogPost",[1050,8797,1090],{"class":1089},[1050,8799,1326],{"class":1278},[1050,8801,1090],{"class":1089},[1050,8803,8804],{"class":1331},"filter",[1050,8806,1197],{"class":1089},[1050,8808,8809],{"class":1341},"title__startswith",[1050,8811,1318],{"class":1089},[1050,8813,1364],{"class":1401},[1050,8815,8816],{"class":1350},"Individual Post",[1050,8818,1364],{"class":1401},[1050,8820,8821],{"class":1089},").",[1050,8823,8824],{"class":1331},"delete",[1050,8826,1825],{"class":1089},[1050,8828,8829],{"class":1052,"line":3562},[1050,8830,1259],{"class":1060},[1050,8832,8833],{"class":1052,"line":3567},[1050,8834,8835],{"class":1265},"        # Test bulk create (fast)\n",[1050,8837,8838,8840,8842,8844,8846,8848,8850],{"class":1052,"line":3589},[1050,8839,2604],{"class":1056},[1050,8841,6647],{"class":1331},[1050,8843,1197],{"class":1089},[1050,8845,7527],{"class":1341},[1050,8847,1318],{"class":1089},[1050,8849,7532],{"class":1784},[1050,8851,1204],{"class":1089},[1050,8853,8854,8856,8858,8860,8862,8864],{"class":1052,"line":3599},[1050,8855,7539],{"class":1060},[1050,8857,1090],{"class":1089},[1050,8859,7544],{"class":1278},[1050,8861,1090],{"class":1089},[1050,8863,7549],{"class":1331},[1050,8865,1825],{"class":1089},[1050,8867,8868],{"class":1052,"line":3617},[1050,8869,2034],{"class":1060},[1050,8871,8872,8874,8876,8878,8880,8882],{"class":1052,"line":3652},[1050,8873,7560],{"class":1060},[1050,8875,1318],{"class":1089},[1050,8877,1880],{"class":1060},[1050,8879,1090],{"class":1089},[1050,8881,1885],{"class":1331},[1050,8883,1825],{"class":1089},[1050,8885,8886],{"class":1052,"line":3688},[1050,8887,2034],{"class":1060},[1050,8889,8890,8893,8895],{"class":1052,"line":3693},[1050,8891,8892],{"class":1060},"            bulk_posts ",[1050,8894,1318],{"class":1089},[1050,8896,1285],{"class":1089},[1050,8898,8899,8901,8903,8905,8907,8909,8911],{"class":1052,"line":3711},[1050,8900,2693],{"class":1056},[1050,8902,1294],{"class":1060},[1050,8904,1297],{"class":1056},[1050,8906,1301],{"class":1300},[1050,8908,1197],{"class":1089},[1050,8910,1565],{"class":1306},[1050,8912,1204],{"class":1089},[1050,8914,8915,8917,8919,8921],{"class":1052,"line":3721},[1050,8916,8621],{"class":1060},[1050,8918,1318],{"class":1089},[1050,8920,1465],{"class":1331},[1050,8922,1335],{"class":1089},[1050,8924,8925,8927,8929,8931,8934,8936,8938,8940,8942],{"class":1052,"line":3732},[1050,8926,8640],{"class":1341},[1050,8928,1318],{"class":1089},[1050,8930,1347],{"class":1189},[1050,8932,8933],{"class":1350},"'Bulk Post ",[1050,8935,1355],{"class":1354},[1050,8937,1358],{"class":1331},[1050,8939,1361],{"class":1354},[1050,8941,1364],{"class":1350},[1050,8943,1367],{"class":1089},[1050,8945,8946,8948,8950,8952,8954,8956,8958,8960,8962],{"class":1052,"line":3746},[1050,8947,8662],{"class":1341},[1050,8949,1318],{"class":1089},[1050,8951,1347],{"class":1189},[1050,8953,8669],{"class":1350},[1050,8955,1355],{"class":1354},[1050,8957,1358],{"class":1331},[1050,8959,1361],{"class":1354},[1050,8961,1364],{"class":1350},[1050,8963,1367],{"class":1089},[1050,8965,8966,8968,8970,8972,8974,8976,8978,8980],{"class":1052,"line":3767},[1050,8967,8684],{"class":1341},[1050,8969,1318],{"class":1089},[1050,8971,1240],{"class":1272},[1050,8973,1090],{"class":1089},[1050,8975,1279],{"class":1278},[1050,8977,1661],{"class":1089},[1050,8979,5865],{"class":1306},[1050,8981,8699],{"class":1089},[1050,8983,8984,8986,8988,8990,8992,8994,8996,8998],{"class":1052,"line":3804},[1050,8985,8704],{"class":1341},[1050,8987,1318],{"class":1089},[1050,8989,1240],{"class":1272},[1050,8991,1090],{"class":1089},[1050,8993,7135],{"class":1278},[1050,8995,1661],{"class":1089},[1050,8997,5865],{"class":1306},[1050,8999,2552],{"class":1089},[1050,9001,9002],{"class":1052,"line":3812},[1050,9003,8723],{"class":1089},[1050,9005,9006,9009,9011,9013,9015,9017],{"class":1052,"line":3817},[1050,9007,9008],{"class":1060},"                bulk_posts",[1050,9010,1090],{"class":1089},[1050,9012,1428],{"class":1331},[1050,9014,1197],{"class":1089},[1050,9016,1735],{"class":1331},[1050,9018,1436],{"class":1089},[1050,9020,9021],{"class":1052,"line":3832},[1050,9022,2034],{"class":1060},[1050,9024,9025,9028,9030,9032,9034,9037,9039,9042],{"class":1052,"line":3842},[1050,9026,9027],{"class":1060},"            BlogPost",[1050,9029,1090],{"class":1089},[1050,9031,1326],{"class":1278},[1050,9033,1090],{"class":1089},[1050,9035,9036],{"class":1331},"bulk_create",[1050,9038,1197],{"class":1089},[1050,9040,9041],{"class":1331},"bulk_posts",[1050,9043,1436],{"class":1089},[1050,9045,9046],{"class":1052,"line":3847},[1050,9047,2034],{"class":1060},[1050,9049,9050,9053,9055,9057,9059,9061,9063,9065],{"class":1052,"line":3861},[1050,9051,9052],{"class":1060},"            bulk_time ",[1050,9054,1318],{"class":1089},[1050,9056,1880],{"class":1060},[1050,9058,1090],{"class":1089},[1050,9060,1885],{"class":1331},[1050,9062,8758],{"class":1089},[1050,9064,3680],{"class":1635},[1050,9066,7721],{"class":1060},[1050,9068,9069,9072,9074,9076,9078,9080,9082,9084],{"class":1052,"line":3871},[1050,9070,9071],{"class":1060},"            bulk_queries ",[1050,9073,1318],{"class":1089},[1050,9075,1670],{"class":1300},[1050,9077,1197],{"class":1089},[1050,9079,7700],{"class":1331},[1050,9081,1090],{"class":1089},[1050,9083,7705],{"class":1278},[1050,9085,1436],{"class":1089},[1050,9087,9088],{"class":1052,"line":3876},[1050,9089,1259],{"class":1060},[1050,9091,9092,9094,9096,9098,9101],{"class":1052,"line":3892},[1050,9093,4082],{"class":1300},[1050,9095,1197],{"class":1089},[1050,9097,1347],{"class":1189},[1050,9099,9100],{"class":1350},"\"Bulk Operations Performance Comparison:\"",[1050,9102,1436],{"class":1089},[1050,9104,9105,9107,9109,9111,9114,9116,9119,9121,9124,9126,9129,9131,9133,9135],{"class":1052,"line":3908},[1050,9106,4082],{"class":1300},[1050,9108,1197],{"class":1089},[1050,9110,1347],{"class":1189},[1050,9112,9113],{"class":1350},"\"Individual Creates: ",[1050,9115,1355],{"class":1354},[1050,9117,9118],{"class":1331},"individual_queries",[1050,9120,1361],{"class":1354},[1050,9122,9123],{"class":1350}," queries, ",[1050,9125,1355],{"class":1354},[1050,9127,9128],{"class":1331},"individual_time",[1050,9130,4156],{"class":1189},[1050,9132,1361],{"class":1354},[1050,9134,4161],{"class":1350},[1050,9136,1436],{"class":1089},[1050,9138,9139,9141,9143,9145,9148,9150,9153,9155,9157,9159,9162,9164,9166,9168],{"class":1052,"line":3921},[1050,9140,4082],{"class":1300},[1050,9142,1197],{"class":1089},[1050,9144,1347],{"class":1189},[1050,9146,9147],{"class":1350},"\"Bulk Create: ",[1050,9149,1355],{"class":1354},[1050,9151,9152],{"class":1331},"bulk_queries",[1050,9154,1361],{"class":1354},[1050,9156,9123],{"class":1350},[1050,9158,1355],{"class":1354},[1050,9160,9161],{"class":1331},"bulk_time",[1050,9163,4156],{"class":1189},[1050,9165,1361],{"class":1354},[1050,9167,4161],{"class":1350},[1050,9169,1436],{"class":1089},[1050,9171,9172],{"class":1052,"line":3932},[1050,9173,1259],{"class":1060},[1050,9175,9176],{"class":1052,"line":3938},[1050,9177,9178],{"class":1265},"        # Bulk operations should be much more efficient\n",[1050,9180,9181,9183,9185,9187,9189,9191,9193,9196,9198,9200,9202],{"class":1052,"line":3943},[1050,9182,1273],{"class":1272},[1050,9184,1090],{"class":1089},[1050,9186,3986],{"class":1331},[1050,9188,1197],{"class":1089},[1050,9190,9152],{"class":1331},[1050,9192,1101],{"class":1089},[1050,9194,9195],{"class":1331}," individual_queries ",[1050,9197,3645],{"class":1635},[1050,9199,4066],{"class":1306},[1050,9201,2619],{"class":1089},[1050,9203,9204],{"class":1265},"  # At least 10x fewer queries\n",[1050,9206,9207,9209,9211,9213,9215,9217,9219,9222,9224,9226,9228],{"class":1052,"line":3949},[1050,9208,1273],{"class":1272},[1050,9210,1090],{"class":1089},[1050,9212,3986],{"class":1331},[1050,9214,1197],{"class":1089},[1050,9216,9161],{"class":1331},[1050,9218,1101],{"class":1089},[1050,9220,9221],{"class":1331}," individual_time ",[1050,9223,3645],{"class":1635},[1050,9225,5294],{"class":1306},[1050,9227,2619],{"class":1089},[1050,9229,9230],{"class":1265},"  # At least 5x faster\n",[1050,9232,9233],{"class":1052,"line":3979},[1050,9234,1224],{"class":1060},[1050,9236,9237,9239,9242,9244,9246],{"class":1052,"line":4011},[1050,9238,1230],{"class":1189},[1050,9240,9241],{"class":1233}," test_pagination_performance",[1050,9243,1197],{"class":1089},[1050,9245,1240],{"class":1239},[1050,9247,1204],{"class":1089},[1050,9249,9250,9252,9255],{"class":1052,"line":4042},[1050,9251,1248],{"class":1210},[1050,9253,9254],{"class":1214},"Test pagination performance with large datasets",[1050,9256,1218],{"class":1210},[1050,9258,9259],{"class":1052,"line":4074},[1050,9260,1259],{"class":1060},[1050,9262,9263,9265,9267,9269,9272,9274,9277,9279],{"class":1052,"line":4079},[1050,9264,1453],{"class":1056},[1050,9266,1112],{"class":1060},[1050,9268,1090],{"class":1089},[1050,9270,9271],{"class":1060},"core",[1050,9273,1090],{"class":1089},[1050,9275,9276],{"class":1060},"paginator ",[1050,9278,1057],{"class":1056},[1050,9280,9281],{"class":1060}," Paginator\n",[1050,9283,9284,9286,9288,9290,9292,9294,9296,9298],{"class":1052,"line":4094},[1050,9285,1453],{"class":1056},[1050,9287,1112],{"class":1060},[1050,9289,1090],{"class":1089},[1050,9291,1139],{"class":1060},[1050,9293,1090],{"class":1089},[1050,9295,1144],{"class":1060},[1050,9297,1057],{"class":1056},[1050,9299,1149],{"class":1060},[1050,9301,9302,9304,9306,9308,9310,9312],{"class":1052,"line":4130},[1050,9303,1453],{"class":1056},[1050,9305,1112],{"class":1060},[1050,9307,1090],{"class":1089},[1050,9309,6608],{"class":1060},[1050,9311,1057],{"class":1056},[1050,9313,7512],{"class":1060},[1050,9315,9316],{"class":1052,"line":4166},[1050,9317,1259],{"class":1060},[1050,9319,9320],{"class":1052,"line":4200},[1050,9321,9322],{"class":1265},"        # Test different pagination approaches\n",[1050,9324,9325,9328,9330],{"class":1052,"line":4234},[1050,9326,9327],{"class":1060},"        approaches ",[1050,9329,1318],{"class":1089},[1050,9331,5265],{"class":1089},[1050,9333,9334,9336,9338,9341,9343,9345,9348,9350,9352,9354,9356,9358,9360],{"class":1052,"line":4239},[1050,9335,5270],{"class":1089},[1050,9337,2026],{"class":1401},[1050,9339,9340],{"class":1350},"Basic Pagination",[1050,9342,2026],{"class":1401},[1050,9344,1101],{"class":1089},[1050,9346,9347],{"class":1189}," lambda",[1050,9349,2078],{"class":1089},[1050,9351,1465],{"class":1060},[1050,9353,1090],{"class":1089},[1050,9355,1326],{"class":1278},[1050,9357,1090],{"class":1089},[1050,9359,7597],{"class":1331},[1050,9361,9362],{"class":1089},"()),\n",[1050,9364,9365,9367,9369,9372,9374,9376,9378,9380,9382,9384,9386,9388,9390,9392,9394,9396,9398,9400,9402,9404,9406],{"class":1052,"line":4253},[1050,9366,5270],{"class":1089},[1050,9368,2026],{"class":1401},[1050,9370,9371],{"class":1350},"Optimized Pagination",[1050,9373,2026],{"class":1401},[1050,9375,1101],{"class":1089},[1050,9377,9347],{"class":1189},[1050,9379,2078],{"class":1089},[1050,9381,1465],{"class":1060},[1050,9383,1090],{"class":1089},[1050,9385,1326],{"class":1278},[1050,9387,1090],{"class":1089},[1050,9389,7967],{"class":1331},[1050,9391,1197],{"class":1089},[1050,9393,1364],{"class":1401},[1050,9395,7641],{"class":1350},[1050,9397,1364],{"class":1401},[1050,9399,1101],{"class":1089},[1050,9401,1915],{"class":1401},[1050,9403,1480],{"class":1350},[1050,9405,1364],{"class":1401},[1050,9407,9408],{"class":1089},")),\n",[1050,9410,9411,9413,9415,9418,9420,9422,9424,9426,9428,9430,9432,9434,9436,9438,9441,9443,9445,9447,9449],{"class":1052,"line":4263},[1050,9412,5270],{"class":1089},[1050,9414,2026],{"class":1401},[1050,9416,9417],{"class":1350},"Filtered Pagination",[1050,9419,2026],{"class":1401},[1050,9421,1101],{"class":1089},[1050,9423,9347],{"class":1189},[1050,9425,2078],{"class":1089},[1050,9427,1465],{"class":1060},[1050,9429,1090],{"class":1089},[1050,9431,1326],{"class":1278},[1050,9433,1090],{"class":1089},[1050,9435,8804],{"class":1331},[1050,9437,1197],{"class":1089},[1050,9439,9440],{"class":1341},"status",[1050,9442,1318],{"class":1089},[1050,9444,1364],{"class":1401},[1050,9446,1710],{"class":1350},[1050,9448,1364],{"class":1401},[1050,9450,9408],{"class":1089},[1050,9452,9453],{"class":1052,"line":4268},[1050,9454,5352],{"class":1089},[1050,9456,9457],{"class":1052,"line":4283},[1050,9458,1259],{"class":1060},[1050,9460,9461,9463,9465],{"class":1052,"line":4299},[1050,9462,2426],{"class":1060},[1050,9464,1318],{"class":1089},[1050,9466,3729],{"class":1089},[1050,9468,9469],{"class":1052,"line":4310},[1050,9470,1259],{"class":1060},[1050,9472,9473,9475,9478,9480,9483,9485,9488],{"class":1052,"line":4320},[1050,9474,1291],{"class":1056},[1050,9476,9477],{"class":1060}," name",[1050,9479,1101],{"class":1089},[1050,9481,9482],{"class":1060}," queryset_func ",[1050,9484,1297],{"class":1056},[1050,9486,9487],{"class":1060}," approaches",[1050,9489,1847],{"class":1089},[1050,9491,9492,9495,9497,9499,9501,9503,9505],{"class":1052,"line":4325},[1050,9493,9494],{"class":1056},"            with",[1050,9496,6647],{"class":1331},[1050,9498,1197],{"class":1089},[1050,9500,7527],{"class":1341},[1050,9502,1318],{"class":1089},[1050,9504,7532],{"class":1784},[1050,9506,1204],{"class":1089},[1050,9508,9509,9512,9514,9516,9518,9520],{"class":1052,"line":4330},[1050,9510,9511],{"class":1060},"                connection",[1050,9513,1090],{"class":1089},[1050,9515,7544],{"class":1278},[1050,9517,1090],{"class":1089},[1050,9519,7549],{"class":1331},[1050,9521,1825],{"class":1089},[1050,9523,9524],{"class":1052,"line":4336},[1050,9525,9526],{"class":1060},"                \n",[1050,9528,9529,9532,9534,9536,9538,9540],{"class":1052,"line":4364},[1050,9530,9531],{"class":1060},"                start_time ",[1050,9533,1318],{"class":1089},[1050,9535,1880],{"class":1060},[1050,9537,1090],{"class":1089},[1050,9539,1885],{"class":1331},[1050,9541,1825],{"class":1089},[1050,9543,9544],{"class":1052,"line":4392},[1050,9545,9526],{"class":1060},[1050,9547,9548,9551,9553,9556],{"class":1052,"line":4420},[1050,9549,9550],{"class":1060},"                queryset ",[1050,9552,1318],{"class":1089},[1050,9554,9555],{"class":1331}," queryset_func",[1050,9557,1825],{"class":1089},[1050,9559,9560,9563,9565,9568,9570,9573,9575,9577,9579],{"class":1052,"line":4425},[1050,9561,9562],{"class":1060},"                paginator ",[1050,9564,1318],{"class":1089},[1050,9566,9567],{"class":1331}," Paginator",[1050,9569,1197],{"class":1089},[1050,9571,9572],{"class":1331},"queryset",[1050,9574,1101],{"class":1089},[1050,9576,5326],{"class":1306},[1050,9578,2619],{"class":1089},[1050,9580,9581],{"class":1265},"  # 20 items per page\n",[1050,9583,9584],{"class":1052,"line":4439},[1050,9585,9526],{"class":1060},[1050,9587,9588],{"class":1052,"line":4472},[1050,9589,9590],{"class":1265},"                # Test accessing different pages\n",[1050,9592,9593,9596,9598,9601,9603,9606,9608,9610],{"class":1052,"line":4505},[1050,9594,9595],{"class":1060},"                page1 ",[1050,9597,1318],{"class":1089},[1050,9599,9600],{"class":1060}," paginator",[1050,9602,1090],{"class":1089},[1050,9604,9605],{"class":1331},"page",[1050,9607,1197],{"class":1089},[1050,9609,5884],{"class":1306},[1050,9611,1436],{"class":1089},[1050,9613,9614,9617,9619,9621,9623,9625,9627,9629],{"class":1052,"line":4537},[1050,9615,9616],{"class":1060},"                page5 ",[1050,9618,1318],{"class":1089},[1050,9620,9600],{"class":1060},[1050,9622,1090],{"class":1089},[1050,9624,9605],{"class":1331},[1050,9626,1197],{"class":1089},[1050,9628,5022],{"class":1306},[1050,9630,1436],{"class":1089},[1050,9632,9633,9636,9638,9640,9642,9644,9646,9648],{"class":1052,"line":4542},[1050,9634,9635],{"class":1060},"                page10 ",[1050,9637,1318],{"class":1089},[1050,9639,9600],{"class":1060},[1050,9641,1090],{"class":1089},[1050,9643,9605],{"class":1331},[1050,9645,1197],{"class":1089},[1050,9647,1307],{"class":1306},[1050,9649,1436],{"class":1089},[1050,9651,9652],{"class":1052,"line":4556},[1050,9653,9526],{"class":1060},[1050,9655,9656],{"class":1052,"line":4566},[1050,9657,9658],{"class":1265},"                # Access items to trigger queries\n",[1050,9660,9661,9664,9666,9668,9671],{"class":1052,"line":4571},[1050,9662,9663],{"class":1056},"                for",[1050,9665,4608],{"class":1060},[1050,9667,1297],{"class":1056},[1050,9669,9670],{"class":1060}," page1",[1050,9672,1847],{"class":1089},[1050,9674,9675,9678,9680,9682,9684],{"class":1052,"line":4577},[1050,9676,9677],{"class":1060},"                    title ",[1050,9679,1318],{"class":1089},[1050,9681,7636],{"class":1060},[1050,9683,1090],{"class":1089},[1050,9685,9686],{"class":1278},"title\n",[1050,9688,9689],{"class":1052,"line":4626},[1050,9690,9526],{"class":1060},[1050,9692,9693,9696,9698,9700,9702,9704],{"class":1052,"line":4631},[1050,9694,9695],{"class":1060},"                end_time ",[1050,9697,1318],{"class":1089},[1050,9699,1880],{"class":1060},[1050,9701,1090],{"class":1089},[1050,9703,1885],{"class":1331},[1050,9705,1825],{"class":1089},[1050,9707,9708],{"class":1052,"line":4641},[1050,9709,9526],{"class":1060},[1050,9711,9712,9715,9717,9719,9721,9723],{"class":1052,"line":4656},[1050,9713,9714],{"class":1060},"                results",[1050,9716,1661],{"class":1089},[1050,9718,1499],{"class":1060},[1050,9720,3020],{"class":1089},[1050,9722,1282],{"class":1089},[1050,9724,2064],{"class":1089},[1050,9726,9727,9729,9731,9733,9735,9737,9739,9741,9743,9745],{"class":1052,"line":4672},[1050,9728,6699],{"class":1401},[1050,9730,7705],{"class":1350},[1050,9732,1364],{"class":1401},[1050,9734,2078],{"class":1089},[1050,9736,1670],{"class":1300},[1050,9738,1197],{"class":1089},[1050,9740,7700],{"class":1331},[1050,9742,1090],{"class":1089},[1050,9744,7705],{"class":1278},[1050,9746,2169],{"class":1089},[1050,9748,9749,9751,9753,9755,9757,9759,9761],{"class":1052,"line":4684},[1050,9750,6699],{"class":1401},[1050,9752,1885],{"class":1350},[1050,9754,1364],{"class":1401},[1050,9756,2078],{"class":1089},[1050,9758,2102],{"class":1060},[1050,9760,2105],{"class":1635},[1050,9762,7721],{"class":1060},[1050,9764,9765],{"class":1052,"line":4697},[1050,9766,6736],{"class":1089},[1050,9768,9769],{"class":1052,"line":4707},[1050,9770,1259],{"class":1060},[1050,9772,9773,9775,9777,9779,9782],{"class":1052,"line":4712},[1050,9774,4082],{"class":1300},[1050,9776,1197],{"class":1089},[1050,9778,1347],{"class":1189},[1050,9780,9781],{"class":1350},"\"Pagination Performance Results:\"",[1050,9783,1436],{"class":1089},[1050,9785,9786,9788,9790,9792,9794,9796,9798,9800,9803],{"class":1052,"line":4728},[1050,9787,1291],{"class":1056},[1050,9789,9477],{"class":1060},[1050,9791,1101],{"class":1089},[1050,9793,3737],{"class":1060},[1050,9795,1297],{"class":1056},[1050,9797,2930],{"class":1060},[1050,9799,1090],{"class":1089},[1050,9801,9802],{"class":1331},"items",[1050,9804,2447],{"class":1089},[1050,9806,9807,9809,9811,9813,9815,9817,9819,9821,9824,9826,9828,9830,9832,9834,9836,9838,9840,9842,9844,9846,9848,9850,9852,9854,9856,9858,9860,9862],{"class":1052,"line":4733},[1050,9808,5392],{"class":1300},[1050,9810,1197],{"class":1089},[1050,9812,1347],{"class":1189},[1050,9814,2026],{"class":1350},[1050,9816,1355],{"class":1354},[1050,9818,1499],{"class":1331},[1050,9820,1361],{"class":1354},[1050,9822,9823],{"class":1350},": ",[1050,9825,1355],{"class":1354},[1050,9827,2732],{"class":1331},[1050,9829,1661],{"class":1089},[1050,9831,1364],{"class":1401},[1050,9833,7705],{"class":1350},[1050,9835,1364],{"class":1401},[1050,9837,3020],{"class":1089},[1050,9839,1361],{"class":1354},[1050,9841,9123],{"class":1350},[1050,9843,1355],{"class":1354},[1050,9845,2732],{"class":1331},[1050,9847,1661],{"class":1089},[1050,9849,1364],{"class":1401},[1050,9851,1885],{"class":1350},[1050,9853,1364],{"class":1401},[1050,9855,3020],{"class":1089},[1050,9857,4156],{"class":1189},[1050,9859,1361],{"class":1354},[1050,9861,4161],{"class":1350},[1050,9863,1436],{"class":1089},[1050,9865,9866],{"class":1052,"line":4739},[1050,9867,1259],{"class":1060},[1050,9869,9870],{"class":1052,"line":4785},[1050,9871,9872],{"class":1265},"        # Optimized pagination should perform better\n",[1050,9874,9875,9878,9880,9882,9884,9886,9888,9890,9893,9895,9897,9899],{"class":1052,"line":4829},[1050,9876,9877],{"class":1060},"        basic_queries ",[1050,9879,1318],{"class":1089},[1050,9881,2930],{"class":1060},[1050,9883,1661],{"class":1089},[1050,9885,2026],{"class":1401},[1050,9887,9340],{"class":1350},[1050,9889,2026],{"class":1401},[1050,9891,9892],{"class":1089},"][",[1050,9894,2026],{"class":1401},[1050,9896,7705],{"class":1350},[1050,9898,2026],{"class":1401},[1050,9900,2552],{"class":1089},[1050,9902,9903,9906,9908,9910,9912,9914,9916,9918,9920,9922,9924,9926],{"class":1052,"line":4834},[1050,9904,9905],{"class":1060},"        optimized_queries ",[1050,9907,1318],{"class":1089},[1050,9909,2930],{"class":1060},[1050,9911,1661],{"class":1089},[1050,9913,2026],{"class":1401},[1050,9915,9371],{"class":1350},[1050,9917,2026],{"class":1401},[1050,9919,9892],{"class":1089},[1050,9921,2026],{"class":1401},[1050,9923,7705],{"class":1350},[1050,9925,2026],{"class":1401},[1050,9927,2552],{"class":1089},[1050,9929,9930],{"class":1052,"line":4854},[1050,9931,1259],{"class":1060},[1050,9933,9934,9936,9938,9940,9942,9945,9947,9950],{"class":1052,"line":4873},[1050,9935,1273],{"class":1272},[1050,9937,1090],{"class":1089},[1050,9939,8180],{"class":1331},[1050,9941,1197],{"class":1089},[1050,9943,9944],{"class":1331},"optimized_queries",[1050,9946,1101],{"class":1089},[1050,9948,9949],{"class":1331}," basic_queries",[1050,9951,1436],{"class":1089},[1030,9953,9955],{"id":9954},"caching-performance-testing","Caching Performance Testing",[1035,9957,9959],{"id":9958},"cache-effectiveness-analysis","Cache Effectiveness Analysis",[1040,9961,9963],{"className":1042,"code":9962,"language":1044,"meta":1045,"style":1045},"class CachePerformanceTests(TestCase):\n    \"\"\"Test caching performance and effectiveness\"\"\"\n    \n    def setUp(self):\n        \"\"\"Set up test data for cache testing\"\"\"\n        \n        from django.core.cache import cache\n        cache.clear()  # Start with clean cache\n        \n        self.user = User.objects.create_user('cacheuser', 'cache@example.com', 'pass')\n        \n        from blog.models import BlogPost, Category\n        self.category = Category.objects.create(name='Cache Test', slug='cache-test')\n        \n        # Create posts for cache testing\n        for i in range(50):\n            BlogPost.objects.create(\n                title=f'Cache Test Post {i}',\n                content=f'Content for cache test post {i}. ' * 20,\n                author=self.user,\n                category=self.category,\n                status='published'\n            )\n    \n    def test_view_caching_performance(self):\n        \"\"\"Test view-level caching performance\"\"\"\n        \n        from django.core.cache import cache\n        \n        # Test without cache (cold)\n        cache.clear()\n        \n        start_time = time.time()\n        response1 = self.client.get('/blog/')\n        cold_time = time.time() - start_time\n        \n        # Test with cache (warm) - assuming view caching is implemented\n        start_time = time.time()\n        response2 = self.client.get('/blog/')\n        warm_time = time.time() - start_time\n        \n        print(f\"View Caching Performance:\")\n        print(f\"Cold Cache: {cold_time:.3f}s\")\n        print(f\"Warm Cache: {warm_time:.3f}s\")\n        \n        # Both should succeed\n        self.assertEqual(response1.status_code, 200)\n        self.assertEqual(response2.status_code, 200)\n        \n        # Warm cache should be faster (if caching is implemented)\n        # Note: This test assumes you have view caching implemented\n        if warm_time \u003C cold_time:\n            improvement = (cold_time - warm_time) / cold_time * 100\n            print(f\"Cache Improvement: {improvement:.1f}%\")\n    \n    def test_database_query_caching(self):\n        \"\"\"Test database query result caching\"\"\"\n        \n        from django.core.cache import cache\n        from django.test.utils import override_settings\n        from django.db import connection\n        \n        # Service that caches expensive queries\n        class CachedBlogService:\n            def get_popular_posts(self, limit=10):\n                cache_key = f'popular_posts_{limit}'\n                \n                # Try cache first\n                cached_posts = cache.get(cache_key)\n                if cached_posts is not None:\n                    return cached_posts\n                \n                # Expensive query simulation\n                posts = list(BlogPost.objects.select_related(\n                    'author', 'category'\n                ).filter(\n                    status='published'\n                ).order_by('-created_at')[:limit])\n                \n                # Cache for 5 minutes\n                cache.set(cache_key, posts, 300)\n                return posts\n        \n        service = CachedBlogService()\n        \n        with override_settings(DEBUG=True):\n            # First call (cache miss)\n            connection.queries_log.clear()\n            start_time = time.time()\n            \n            posts1 = service.get_popular_posts(10)\n            \n            miss_time = time.time() - start_time\n            miss_queries = len(connection.queries)\n            \n            # Second call (cache hit)\n            connection.queries_log.clear()\n            start_time = time.time()\n            \n            posts2 = service.get_popular_posts(10)\n            \n            hit_time = time.time() - start_time\n            hit_queries = len(connection.queries)\n        \n        print(f\"Database Query Caching Performance:\")\n        print(f\"Cache Miss: {miss_queries} queries, {miss_time:.3f}s\")\n        print(f\"Cache Hit: {hit_queries} queries, {hit_time:.3f}s\")\n        \n        # Results should be identical\n        self.assertEqual(len(posts1), len(posts2))\n        \n        # Cache hit should be much faster\n        self.assertEqual(hit_queries, 0)  # No database queries on cache hit\n        self.assertLess(hit_time, miss_time / 10)  # At least 10x faster\n    \n    def test_cache_invalidation_performance(self):\n        \"\"\"Test cache invalidation strategies\"\"\"\n        \n        from django.core.cache import cache\n        \n        # Cache some data\n        cache.set('test_key_1', 'value_1', 300)\n        cache.set('test_key_2', 'value_2', 300)\n        cache.set('test_key_3', 'value_3', 300)\n        \n        # Test individual key deletion\n        start_time = time.time()\n        cache.delete('test_key_1')\n        individual_delete_time = time.time() - start_time\n        \n        # Test pattern-based deletion (if supported)\n        start_time = time.time()\n        cache.delete_many(['test_key_2', 'test_key_3'])\n        batch_delete_time = time.time() - start_time\n        \n        print(f\"Cache Invalidation Performance:\")\n        print(f\"Individual Delete: {individual_delete_time:.6f}s\")\n        print(f\"Batch Delete: {batch_delete_time:.6f}s\")\n        \n        # Verify deletions\n        self.assertIsNone(cache.get('test_key_1'))\n        self.assertIsNone(cache.get('test_key_2'))\n        self.assertIsNone(cache.get('test_key_3'))\n    \n    def test_cache_memory_usage(self):\n        \"\"\"Test cache memory usage patterns\"\"\"\n        \n        from django.core.cache import cache\n        import sys\n        \n        # Clear cache and measure baseline\n        cache.clear()\n        \n        # Store large amounts of data in cache\n        large_data = 'x' * 10000  # 10KB string\n        \n        start_time = time.time()\n        \n        # Cache many large objects\n        for i in range(100):\n            cache.set(f'large_key_{i}', large_data, 300)\n        \n        cache_write_time = time.time() - start_time\n        \n        # Read from cache\n        start_time = time.time()\n        \n        retrieved_data = []\n        for i in range(100):\n            data = cache.get(f'large_key_{i}')\n            retrieved_data.append(data)\n        \n        cache_read_time = time.time() - start_time\n        \n        print(f\"Cache Memory Usage Performance:\")\n        print(f\"Write 100 x 10KB objects: {cache_write_time:.3f}s\")\n        print(f\"Read 100 x 10KB objects: {cache_read_time:.3f}s\")\n        \n        # Verify all data was cached and retrieved\n        self.assertEqual(len(retrieved_data), 100)\n        self.assertTrue(all(data == large_data for data in retrieved_data))\n        \n        # Cache operations should be fast\n        self.assertLess(cache_write_time, 1.0)\n        self.assertLess(cache_read_time, 0.5)\n",[1047,9964,9965,9978,9987,9991,10003,10012,10016,10036,10050,10054,10103,10107,10125,10173,10177,10182,10198,10212,10233,10258,10272,10286,10298,10302,10306,10319,10328,10332,10350,10354,10359,10369,10373,10387,10415,10434,10438,10443,10457,10484,10503,10507,10520,10544,10568,10572,10577,10601,10624,10628,10633,10638,10653,10681,10705,10709,10722,10731,10735,10753,10771,10785,10789,10794,10804,10827,10848,10852,10857,10878,10896,10904,10908,10913,10938,10954,10963,10976,11000,11004,11009,11034,11042,11046,11057,11061,11077,11082,11096,11110,11114,11135,11139,11158,11177,11181,11186,11200,11214,11218,11237,11241,11260,11279,11283,11296,11329,11362,11366,11371,11400,11404,11409,11430,11456,11460,11473,11482,11486,11504,11508,11513,11545,11577,11609,11613,11618,11632,11650,11669,11673,11678,11692,11720,11739,11743,11756,11781,11805,11809,11814,11842,11868,11894,11898,11911,11920,11924,11942,11949,11953,11958,11968,11972,11977,11999,12003,12017,12021,12026,12042,12077,12081,12100,12104,12109,12123,12127,12136,12152,12181,12196,12200,12219,12223,12236,12260,12284,12288,12293,12316,12350,12354,12359,12378],{"__ignoreMap":1045},[1050,9966,9967,9969,9972,9974,9976],{"class":1052,"line":1053},[1050,9968,1190],{"class":1189},[1050,9970,9971],{"class":1193}," CachePerformanceTests",[1050,9973,1197],{"class":1089},[1050,9975,1201],{"class":1200},[1050,9977,1204],{"class":1089},[1050,9979,9980,9982,9985],{"class":1052,"line":1064},[1050,9981,1211],{"class":1210},[1050,9983,9984],{"class":1214},"Test caching performance and effectiveness",[1050,9986,1218],{"class":1210},[1050,9988,9989],{"class":1052,"line":1072},[1050,9990,1224],{"class":1060},[1050,9992,9993,9995,9997,9999,10001],{"class":1052,"line":1080},[1050,9994,1230],{"class":1189},[1050,9996,1234],{"class":1233},[1050,9998,1197],{"class":1089},[1050,10000,1240],{"class":1239},[1050,10002,1204],{"class":1089},[1050,10004,10005,10007,10010],{"class":1052,"line":1107},[1050,10006,1248],{"class":1210},[1050,10008,10009],{"class":1214},"Set up test data for cache testing",[1050,10011,1218],{"class":1210},[1050,10013,10014],{"class":1052,"line":1130},[1050,10015,1259],{"class":1060},[1050,10017,10018,10020,10022,10024,10026,10028,10031,10033],{"class":1052,"line":1152},[1050,10019,1453],{"class":1056},[1050,10021,1112],{"class":1060},[1050,10023,1090],{"class":1089},[1050,10025,9271],{"class":1060},[1050,10027,1090],{"class":1089},[1050,10029,10030],{"class":1060},"cache ",[1050,10032,1057],{"class":1056},[1050,10034,10035],{"class":1060}," cache\n",[1050,10037,10038,10041,10043,10045,10047],{"class":1052,"line":1179},[1050,10039,10040],{"class":1060},"        cache",[1050,10042,1090],{"class":1089},[1050,10044,7549],{"class":1331},[1050,10046,8758],{"class":1089},[1050,10048,10049],{"class":1265},"  # Start with clean cache\n",[1050,10051,10052],{"class":1052,"line":1186},[1050,10053,1259],{"class":1060},[1050,10055,10056,10058,10060,10062,10064,10066,10068,10070,10072,10074,10076,10078,10081,10083,10085,10087,10090,10092,10094,10096,10099,10101],{"class":1052,"line":1207},[1050,10057,1273],{"class":1272},[1050,10059,1090],{"class":1089},[1050,10061,1433],{"class":1278},[1050,10063,1282],{"class":1089},[1050,10065,1321],{"class":1060},[1050,10067,1090],{"class":1089},[1050,10069,1326],{"class":1278},[1050,10071,1090],{"class":1089},[1050,10073,1332],{"class":1331},[1050,10075,1197],{"class":1089},[1050,10077,1364],{"class":1401},[1050,10079,10080],{"class":1350},"cacheuser",[1050,10082,1364],{"class":1401},[1050,10084,1101],{"class":1089},[1050,10086,1915],{"class":1401},[1050,10088,10089],{"class":1350},"cache@example.com",[1050,10091,1364],{"class":1401},[1050,10093,1101],{"class":1089},[1050,10095,1915],{"class":1401},[1050,10097,10098],{"class":1350},"pass",[1050,10100,1364],{"class":1401},[1050,10102,1436],{"class":1089},[1050,10104,10105],{"class":1052,"line":1221},[1050,10106,1259],{"class":1060},[1050,10108,10109,10111,10113,10115,10117,10119,10121,10123],{"class":1052,"line":1227},[1050,10110,1453],{"class":1056},[1050,10112,1456],{"class":1060},[1050,10114,1090],{"class":1089},[1050,10116,1171],{"class":1060},[1050,10118,1057],{"class":1056},[1050,10120,1465],{"class":1060},[1050,10122,1101],{"class":1089},[1050,10124,1470],{"class":1060},[1050,10126,10127,10129,10131,10133,10135,10137,10139,10141,10143,10145,10147,10149,10151,10153,10156,10158,10160,10162,10164,10166,10169,10171],{"class":1052,"line":1245},[1050,10128,1273],{"class":1272},[1050,10130,1090],{"class":1089},[1050,10132,1480],{"class":1278},[1050,10134,1282],{"class":1089},[1050,10136,1485],{"class":1060},[1050,10138,1090],{"class":1089},[1050,10140,1326],{"class":1278},[1050,10142,1090],{"class":1089},[1050,10144,1494],{"class":1331},[1050,10146,1197],{"class":1089},[1050,10148,1499],{"class":1341},[1050,10150,1318],{"class":1089},[1050,10152,1364],{"class":1401},[1050,10154,10155],{"class":1350},"Cache Test",[1050,10157,1364],{"class":1401},[1050,10159,1101],{"class":1089},[1050,10161,1513],{"class":1341},[1050,10163,1318],{"class":1089},[1050,10165,1364],{"class":1401},[1050,10167,10168],{"class":1350},"cache-test",[1050,10170,1364],{"class":1401},[1050,10172,1436],{"class":1089},[1050,10174,10175],{"class":1052,"line":1256},[1050,10176,1259],{"class":1060},[1050,10178,10179],{"class":1052,"line":1262},[1050,10180,10181],{"class":1265},"        # Create posts for cache testing\n",[1050,10183,10184,10186,10188,10190,10192,10194,10196],{"class":1052,"line":1269},[1050,10185,1291],{"class":1056},[1050,10187,1294],{"class":1060},[1050,10189,1297],{"class":1056},[1050,10191,1301],{"class":1300},[1050,10193,1197],{"class":1089},[1050,10195,3916],{"class":1306},[1050,10197,1204],{"class":1089},[1050,10199,10200,10202,10204,10206,10208,10210],{"class":1052,"line":1288},[1050,10201,9027],{"class":1060},[1050,10203,1090],{"class":1089},[1050,10205,1326],{"class":1278},[1050,10207,1090],{"class":1089},[1050,10209,1494],{"class":1331},[1050,10211,1335],{"class":1089},[1050,10213,10214,10216,10218,10220,10223,10225,10227,10229,10231],{"class":1052,"line":1312},[1050,10215,1593],{"class":1341},[1050,10217,1318],{"class":1089},[1050,10219,1347],{"class":1189},[1050,10221,10222],{"class":1350},"'Cache Test Post ",[1050,10224,1355],{"class":1354},[1050,10226,1358],{"class":1331},[1050,10228,1361],{"class":1354},[1050,10230,1364],{"class":1350},[1050,10232,1367],{"class":1089},[1050,10234,10235,10237,10239,10241,10244,10246,10248,10250,10252,10254,10256],{"class":1052,"line":1338},[1050,10236,1616],{"class":1341},[1050,10238,1318],{"class":1089},[1050,10240,1347],{"class":1189},[1050,10242,10243],{"class":1350},"'Content for cache test post ",[1050,10245,1355],{"class":1354},[1050,10247,1358],{"class":1331},[1050,10249,1361],{"class":1354},[1050,10251,1632],{"class":1350},[1050,10253,1636],{"class":1635},[1050,10255,5326],{"class":1306},[1050,10257,1367],{"class":1089},[1050,10259,10260,10262,10264,10266,10268,10270],{"class":1052,"line":1370},[1050,10261,1650],{"class":1341},[1050,10263,1318],{"class":1089},[1050,10265,1240],{"class":1272},[1050,10267,1090],{"class":1089},[1050,10269,1433],{"class":1278},[1050,10271,1367],{"class":1089},[1050,10273,10274,10276,10278,10280,10282,10284],{"class":1052,"line":1393},[1050,10275,1687],{"class":1341},[1050,10277,1318],{"class":1089},[1050,10279,1240],{"class":1272},[1050,10281,1090],{"class":1089},[1050,10283,1480],{"class":1278},[1050,10285,1367],{"class":1089},[1050,10287,10288,10290,10292,10294,10296],{"class":1052,"line":1410},[1050,10289,1703],{"class":1341},[1050,10291,1318],{"class":1089},[1050,10293,1364],{"class":1401},[1050,10295,1710],{"class":1350},[1050,10297,1407],{"class":1401},[1050,10299,10300],{"class":1052,"line":1416},[1050,10301,1413],{"class":1089},[1050,10303,10304],{"class":1052,"line":1439},[1050,10305,1224],{"class":1060},[1050,10307,10308,10310,10313,10315,10317],{"class":1052,"line":1444},[1050,10309,1230],{"class":1189},[1050,10311,10312],{"class":1233}," test_view_caching_performance",[1050,10314,1197],{"class":1089},[1050,10316,1240],{"class":1239},[1050,10318,1204],{"class":1089},[1050,10320,10321,10323,10326],{"class":1052,"line":1450},[1050,10322,1248],{"class":1210},[1050,10324,10325],{"class":1214},"Test view-level caching performance",[1050,10327,1218],{"class":1210},[1050,10329,10330],{"class":1052,"line":1473},[1050,10331,1259],{"class":1060},[1050,10333,10334,10336,10338,10340,10342,10344,10346,10348],{"class":1052,"line":1527},[1050,10335,1453],{"class":1056},[1050,10337,1112],{"class":1060},[1050,10339,1090],{"class":1089},[1050,10341,9271],{"class":1060},[1050,10343,1090],{"class":1089},[1050,10345,10030],{"class":1060},[1050,10347,1057],{"class":1056},[1050,10349,10035],{"class":1060},[1050,10351,10352],{"class":1052,"line":1532},[1050,10353,1259],{"class":1060},[1050,10355,10356],{"class":1052,"line":1538},[1050,10357,10358],{"class":1265},"        # Test without cache (cold)\n",[1050,10360,10361,10363,10365,10367],{"class":1052,"line":1552},[1050,10362,10040],{"class":1060},[1050,10364,1090],{"class":1089},[1050,10366,7549],{"class":1331},[1050,10368,1825],{"class":1089},[1050,10370,10371],{"class":1052,"line":1570},[1050,10372,1259],{"class":1060},[1050,10374,10375,10377,10379,10381,10383,10385],{"class":1052,"line":1590},[1050,10376,1875],{"class":1060},[1050,10378,1318],{"class":1089},[1050,10380,1880],{"class":1060},[1050,10382,1090],{"class":1089},[1050,10384,1885],{"class":1331},[1050,10386,1825],{"class":1089},[1050,10388,10389,10392,10394,10396,10398,10401,10403,10405,10407,10409,10411,10413],{"class":1052,"line":1613},[1050,10390,10391],{"class":1060},"        response1 ",[1050,10393,1318],{"class":1089},[1050,10395,2481],{"class":1272},[1050,10397,1090],{"class":1089},[1050,10399,10400],{"class":1278},"client",[1050,10402,1090],{"class":1089},[1050,10404,1937],{"class":1331},[1050,10406,1197],{"class":1089},[1050,10408,1364],{"class":1401},[1050,10410,4292],{"class":1350},[1050,10412,1364],{"class":1401},[1050,10414,1436],{"class":1089},[1050,10416,10417,10420,10422,10424,10426,10428,10430,10432],{"class":1052,"line":1647},[1050,10418,10419],{"class":1060},"        cold_time ",[1050,10421,1318],{"class":1089},[1050,10423,1880],{"class":1060},[1050,10425,1090],{"class":1089},[1050,10427,1885],{"class":1331},[1050,10429,8758],{"class":1089},[1050,10431,3680],{"class":1635},[1050,10433,7721],{"class":1060},[1050,10435,10436],{"class":1052,"line":1684},[1050,10437,1259],{"class":1060},[1050,10439,10440],{"class":1052,"line":1700},[1050,10441,10442],{"class":1265},"        # Test with cache (warm) - assuming view caching is implemented\n",[1050,10444,10445,10447,10449,10451,10453,10455],{"class":1052,"line":1715},[1050,10446,1875],{"class":1060},[1050,10448,1318],{"class":1089},[1050,10450,1880],{"class":1060},[1050,10452,1090],{"class":1089},[1050,10454,1885],{"class":1331},[1050,10456,1825],{"class":1089},[1050,10458,10459,10462,10464,10466,10468,10470,10472,10474,10476,10478,10480,10482],{"class":1052,"line":1720},[1050,10460,10461],{"class":1060},"        response2 ",[1050,10463,1318],{"class":1089},[1050,10465,2481],{"class":1272},[1050,10467,1090],{"class":1089},[1050,10469,10400],{"class":1278},[1050,10471,1090],{"class":1089},[1050,10473,1937],{"class":1331},[1050,10475,1197],{"class":1089},[1050,10477,1364],{"class":1401},[1050,10479,4292],{"class":1350},[1050,10481,1364],{"class":1401},[1050,10483,1436],{"class":1089},[1050,10485,10486,10489,10491,10493,10495,10497,10499,10501],{"class":1052,"line":1740},[1050,10487,10488],{"class":1060},"        warm_time ",[1050,10490,1318],{"class":1089},[1050,10492,1880],{"class":1060},[1050,10494,1090],{"class":1089},[1050,10496,1885],{"class":1331},[1050,10498,8758],{"class":1089},[1050,10500,3680],{"class":1635},[1050,10502,7721],{"class":1060},[1050,10504,10505],{"class":1052,"line":1745},[1050,10506,1259],{"class":1060},[1050,10508,10509,10511,10513,10515,10518],{"class":1052,"line":1799},[1050,10510,4082],{"class":1300},[1050,10512,1197],{"class":1089},[1050,10514,1347],{"class":1189},[1050,10516,10517],{"class":1350},"\"View Caching Performance:\"",[1050,10519,1436],{"class":1089},[1050,10521,10522,10524,10526,10528,10531,10533,10536,10538,10540,10542],{"class":1052,"line":1809},[1050,10523,4082],{"class":1300},[1050,10525,1197],{"class":1089},[1050,10527,1347],{"class":1189},[1050,10529,10530],{"class":1350},"\"Cold Cache: ",[1050,10532,1355],{"class":1354},[1050,10534,10535],{"class":1331},"cold_time",[1050,10537,4156],{"class":1189},[1050,10539,1361],{"class":1354},[1050,10541,4161],{"class":1350},[1050,10543,1436],{"class":1089},[1050,10545,10546,10548,10550,10552,10555,10557,10560,10562,10564,10566],{"class":1052,"line":1814},[1050,10547,4082],{"class":1300},[1050,10549,1197],{"class":1089},[1050,10551,1347],{"class":1189},[1050,10553,10554],{"class":1350},"\"Warm Cache: ",[1050,10556,1355],{"class":1354},[1050,10558,10559],{"class":1331},"warm_time",[1050,10561,4156],{"class":1189},[1050,10563,1361],{"class":1354},[1050,10565,4161],{"class":1350},[1050,10567,1436],{"class":1089},[1050,10569,10570],{"class":1052,"line":1828},[1050,10571,1259],{"class":1060},[1050,10573,10574],{"class":1052,"line":1833},[1050,10575,10576],{"class":1265},"        # Both should succeed\n",[1050,10578,10579,10581,10583,10586,10588,10591,10593,10595,10597,10599],{"class":1052,"line":1839},[1050,10580,1273],{"class":1272},[1050,10582,1090],{"class":1089},[1050,10584,10585],{"class":1331},"assertEqual",[1050,10587,1197],{"class":1089},[1050,10589,10590],{"class":1331},"response1",[1050,10592,1090],{"class":1089},[1050,10594,2073],{"class":1278},[1050,10596,1101],{"class":1089},[1050,10598,2125],{"class":1306},[1050,10600,1436],{"class":1089},[1050,10602,10603,10605,10607,10609,10611,10614,10616,10618,10620,10622],{"class":1052,"line":1850},[1050,10604,1273],{"class":1272},[1050,10606,1090],{"class":1089},[1050,10608,10585],{"class":1331},[1050,10610,1197],{"class":1089},[1050,10612,10613],{"class":1331},"response2",[1050,10615,1090],{"class":1089},[1050,10617,2073],{"class":1278},[1050,10619,1101],{"class":1089},[1050,10621,2125],{"class":1306},[1050,10623,1436],{"class":1089},[1050,10625,10626],{"class":1052,"line":1867},[1050,10627,1259],{"class":1060},[1050,10629,10630],{"class":1052,"line":1872},[1050,10631,10632],{"class":1265},"        # Warm cache should be faster (if caching is implemented)\n",[1050,10634,10635],{"class":1052,"line":1890},[1050,10636,10637],{"class":1265},"        # Note: This test assumes you have view caching implemented\n",[1050,10639,10640,10642,10645,10648,10651],{"class":1052,"line":1895},[1050,10641,1842],{"class":1056},[1050,10643,10644],{"class":1060}," warm_time ",[1050,10646,10647],{"class":1635},"\u003C",[1050,10649,10650],{"class":1060}," cold_time",[1050,10652,1847],{"class":1089},[1050,10654,10655,10658,10660,10662,10665,10667,10670,10672,10674,10677,10679],{"class":1052,"line":1903},[1050,10656,10657],{"class":1060},"            improvement ",[1050,10659,1318],{"class":1089},[1050,10661,5499],{"class":1089},[1050,10663,10664],{"class":1060},"cold_time ",[1050,10666,2105],{"class":1635},[1050,10668,10669],{"class":1060}," warm_time",[1050,10671,2619],{"class":1089},[1050,10673,3212],{"class":1635},[1050,10675,10676],{"class":1060}," cold_time ",[1050,10678,8318],{"class":1635},[1050,10680,8321],{"class":1306},[1050,10682,10683,10685,10687,10689,10692,10694,10697,10699,10701,10703],{"class":1052,"line":1924},[1050,10684,5392],{"class":1300},[1050,10686,1197],{"class":1089},[1050,10688,1347],{"class":1189},[1050,10690,10691],{"class":1350},"\"Cache Improvement: ",[1050,10693,1355],{"class":1354},[1050,10695,10696],{"class":1331},"improvement",[1050,10698,4120],{"class":1189},[1050,10700,1361],{"class":1354},[1050,10702,4125],{"class":1350},[1050,10704,1436],{"class":1089},[1050,10706,10707],{"class":1052,"line":1947},[1050,10708,1224],{"class":1060},[1050,10710,10711,10713,10716,10718,10720],{"class":1052,"line":1966},[1050,10712,1230],{"class":1189},[1050,10714,10715],{"class":1233}," test_database_query_caching",[1050,10717,1197],{"class":1089},[1050,10719,1240],{"class":1239},[1050,10721,1204],{"class":1089},[1050,10723,10724,10726,10729],{"class":1052,"line":1994},[1050,10725,1248],{"class":1210},[1050,10727,10728],{"class":1214},"Test database query result caching",[1050,10730,1218],{"class":1210},[1050,10732,10733],{"class":1052,"line":2002},[1050,10734,1259],{"class":1060},[1050,10736,10737,10739,10741,10743,10745,10747,10749,10751],{"class":1052,"line":2031},[1050,10738,1453],{"class":1056},[1050,10740,1112],{"class":1060},[1050,10742,1090],{"class":1089},[1050,10744,9271],{"class":1060},[1050,10746,1090],{"class":1089},[1050,10748,10030],{"class":1060},[1050,10750,1057],{"class":1056},[1050,10752,10035],{"class":1060},[1050,10754,10755,10757,10759,10761,10763,10765,10767,10769],{"class":1052,"line":2037},[1050,10756,1453],{"class":1056},[1050,10758,1112],{"class":1060},[1050,10760,1090],{"class":1089},[1050,10762,1139],{"class":1060},[1050,10764,1090],{"class":1089},[1050,10766,1144],{"class":1060},[1050,10768,1057],{"class":1056},[1050,10770,1149],{"class":1060},[1050,10772,10773,10775,10777,10779,10781,10783],{"class":1052,"line":2053},[1050,10774,1453],{"class":1056},[1050,10776,1112],{"class":1060},[1050,10778,1090],{"class":1089},[1050,10780,6608],{"class":1060},[1050,10782,1057],{"class":1056},[1050,10784,7512],{"class":1060},[1050,10786,10787],{"class":1052,"line":2058},[1050,10788,1259],{"class":1060},[1050,10790,10791],{"class":1052,"line":2067},[1050,10792,10793],{"class":1265},"        # Service that caches expensive queries\n",[1050,10795,10796,10799,10802],{"class":1052,"line":2090},[1050,10797,10798],{"class":1189},"        class",[1050,10800,10801],{"class":1193}," CachedBlogService",[1050,10803,1847],{"class":1089},[1050,10805,10806,10809,10812,10814,10816,10818,10821,10823,10825],{"class":1052,"line":2113},[1050,10807,10808],{"class":1189},"            def",[1050,10810,10811],{"class":1233}," get_popular_posts",[1050,10813,1197],{"class":1089},[1050,10815,1240],{"class":1239},[1050,10817,1101],{"class":1089},[1050,10819,10820],{"class":1759}," limit",[1050,10822,1318],{"class":1635},[1050,10824,1307],{"class":1306},[1050,10826,1204],{"class":1089},[1050,10828,10829,10832,10834,10836,10839,10841,10844,10846],{"class":1052,"line":2145},[1050,10830,10831],{"class":1060},"                cache_key ",[1050,10833,1318],{"class":1089},[1050,10835,2865],{"class":1189},[1050,10837,10838],{"class":1350},"'popular_posts_",[1050,10840,1355],{"class":1354},[1050,10842,10843],{"class":1060},"limit",[1050,10845,1361],{"class":1354},[1050,10847,1407],{"class":1350},[1050,10849,10850],{"class":1052,"line":2172},[1050,10851,9526],{"class":1060},[1050,10853,10854],{"class":1052,"line":2187},[1050,10855,10856],{"class":1265},"                # Try cache first\n",[1050,10858,10859,10862,10864,10867,10869,10871,10873,10876],{"class":1052,"line":2193},[1050,10860,10861],{"class":1060},"                cached_posts ",[1050,10863,1318],{"class":1089},[1050,10865,10866],{"class":1060}," cache",[1050,10868,1090],{"class":1089},[1050,10870,1937],{"class":1331},[1050,10872,1197],{"class":1089},[1050,10874,10875],{"class":1331},"cache_key",[1050,10877,1436],{"class":1089},[1050,10879,10880,10883,10886,10889,10891,10894],{"class":1052,"line":2198},[1050,10881,10882],{"class":1056},"                if",[1050,10884,10885],{"class":1060}," cached_posts ",[1050,10887,10888],{"class":1635},"is",[1050,10890,2955],{"class":1635},[1050,10892,10893],{"class":1784}," None",[1050,10895,1847],{"class":1089},[1050,10897,10898,10901],{"class":1052,"line":2215},[1050,10899,10900],{"class":1056},"                    return",[1050,10902,10903],{"class":1060}," cached_posts\n",[1050,10905,10906],{"class":1052,"line":2230},[1050,10907,9526],{"class":1060},[1050,10909,10910],{"class":1052,"line":2237},[1050,10911,10912],{"class":1265},"                # Expensive query simulation\n",[1050,10914,10915,10918,10920,10923,10925,10928,10930,10932,10934,10936],{"class":1052,"line":2253},[1050,10916,10917],{"class":1060},"                posts ",[1050,10919,1318],{"class":1089},[1050,10921,10922],{"class":2008}," list",[1050,10924,1197],{"class":1089},[1050,10926,10927],{"class":1331},"BlogPost",[1050,10929,1090],{"class":1089},[1050,10931,1326],{"class":1278},[1050,10933,1090],{"class":1089},[1050,10935,7967],{"class":1331},[1050,10937,1335],{"class":1089},[1050,10939,10940,10942,10944,10946,10948,10950,10952],{"class":1052,"line":2272},[1050,10941,6699],{"class":1401},[1050,10943,7641],{"class":1350},[1050,10945,1364],{"class":1401},[1050,10947,1101],{"class":1089},[1050,10949,1915],{"class":1401},[1050,10951,1480],{"class":1350},[1050,10953,1407],{"class":1401},[1050,10955,10956,10959,10961],{"class":1052,"line":2288},[1050,10957,10958],{"class":1089},"                ).",[1050,10960,8804],{"class":1331},[1050,10962,1335],{"class":1089},[1050,10964,10965,10968,10970,10972,10974],{"class":1052,"line":2304},[1050,10966,10967],{"class":1341},"                    status",[1050,10969,1318],{"class":1089},[1050,10971,1364],{"class":1401},[1050,10973,1710],{"class":1350},[1050,10975,1407],{"class":1401},[1050,10977,10978,10980,10983,10985,10987,10990,10992,10995,10997],{"class":1052,"line":2325},[1050,10979,10958],{"class":1089},[1050,10981,10982],{"class":1331},"order_by",[1050,10984,1197],{"class":1089},[1050,10986,1364],{"class":1401},[1050,10988,10989],{"class":1350},"-created_at",[1050,10991,1364],{"class":1401},[1050,10993,10994],{"class":1089},")[:",[1050,10996,10843],{"class":1331},[1050,10998,10999],{"class":1089},"])\n",[1050,11001,11002],{"class":1052,"line":2330},[1050,11003,9526],{"class":1060},[1050,11005,11006],{"class":1052,"line":2335},[1050,11007,11008],{"class":1265},"                # Cache for 5 minutes\n",[1050,11010,11011,11014,11016,11019,11021,11023,11025,11027,11029,11032],{"class":1052,"line":2374},[1050,11012,11013],{"class":1060},"                cache",[1050,11015,1090],{"class":1089},[1050,11017,11018],{"class":1331},"set",[1050,11020,1197],{"class":1089},[1050,11022,10875],{"class":1331},[1050,11024,1101],{"class":1089},[1050,11026,7619],{"class":1331},[1050,11028,1101],{"class":1089},[1050,11030,11031],{"class":1306}," 300",[1050,11033,1436],{"class":1089},[1050,11035,11036,11039],{"class":1052,"line":2408},[1050,11037,11038],{"class":1056},"                return",[1050,11040,11041],{"class":1060}," posts\n",[1050,11043,11044],{"class":1052,"line":2418},[1050,11045,1259],{"class":1060},[1050,11047,11048,11051,11053,11055],{"class":1052,"line":2423},[1050,11049,11050],{"class":1060},"        service ",[1050,11052,1318],{"class":1089},[1050,11054,10801],{"class":1331},[1050,11056,1825],{"class":1089},[1050,11058,11059],{"class":1052,"line":2433},[1050,11060,1259],{"class":1060},[1050,11062,11063,11065,11067,11069,11071,11073,11075],{"class":1052,"line":2438},[1050,11064,2604],{"class":1056},[1050,11066,6647],{"class":1331},[1050,11068,1197],{"class":1089},[1050,11070,7527],{"class":1341},[1050,11072,1318],{"class":1089},[1050,11074,7532],{"class":1784},[1050,11076,1204],{"class":1089},[1050,11078,11079],{"class":1052,"line":2450},[1050,11080,11081],{"class":1265},"            # First call (cache miss)\n",[1050,11083,11084,11086,11088,11090,11092,11094],{"class":1052,"line":2461},[1050,11085,7539],{"class":1060},[1050,11087,1090],{"class":1089},[1050,11089,7544],{"class":1278},[1050,11091,1090],{"class":1089},[1050,11093,7549],{"class":1331},[1050,11095,1825],{"class":1089},[1050,11097,11098,11100,11102,11104,11106,11108],{"class":1052,"line":2470},[1050,11099,7560],{"class":1060},[1050,11101,1318],{"class":1089},[1050,11103,1880],{"class":1060},[1050,11105,1090],{"class":1089},[1050,11107,1885],{"class":1331},[1050,11109,1825],{"class":1089},[1050,11111,11112],{"class":1052,"line":2490},[1050,11113,2034],{"class":1060},[1050,11115,11116,11119,11121,11124,11126,11129,11131,11133],{"class":1052,"line":2496},[1050,11117,11118],{"class":1060},"            posts1 ",[1050,11120,1318],{"class":1089},[1050,11122,11123],{"class":1060}," service",[1050,11125,1090],{"class":1089},[1050,11127,11128],{"class":1331},"get_popular_posts",[1050,11130,1197],{"class":1089},[1050,11132,1307],{"class":1306},[1050,11134,1436],{"class":1089},[1050,11136,11137],{"class":1052,"line":2533},[1050,11138,2034],{"class":1060},[1050,11140,11141,11144,11146,11148,11150,11152,11154,11156],{"class":1052,"line":2555},[1050,11142,11143],{"class":1060},"            miss_time ",[1050,11145,1318],{"class":1089},[1050,11147,1880],{"class":1060},[1050,11149,1090],{"class":1089},[1050,11151,1885],{"class":1331},[1050,11153,8758],{"class":1089},[1050,11155,3680],{"class":1635},[1050,11157,7721],{"class":1060},[1050,11159,11160,11163,11165,11167,11169,11171,11173,11175],{"class":1052,"line":2560},[1050,11161,11162],{"class":1060},"            miss_queries ",[1050,11164,1318],{"class":1089},[1050,11166,1670],{"class":1300},[1050,11168,1197],{"class":1089},[1050,11170,7700],{"class":1331},[1050,11172,1090],{"class":1089},[1050,11174,7705],{"class":1278},[1050,11176,1436],{"class":1089},[1050,11178,11179],{"class":1052,"line":2590},[1050,11180,2034],{"class":1060},[1050,11182,11183],{"class":1052,"line":2595},[1050,11184,11185],{"class":1265},"            # Second call (cache hit)\n",[1050,11187,11188,11190,11192,11194,11196,11198],{"class":1052,"line":2601},[1050,11189,7539],{"class":1060},[1050,11191,1090],{"class":1089},[1050,11193,7544],{"class":1278},[1050,11195,1090],{"class":1089},[1050,11197,7549],{"class":1331},[1050,11199,1825],{"class":1089},[1050,11201,11202,11204,11206,11208,11210,11212],{"class":1052,"line":2629},[1050,11203,7560],{"class":1060},[1050,11205,1318],{"class":1089},[1050,11207,1880],{"class":1060},[1050,11209,1090],{"class":1089},[1050,11211,1885],{"class":1331},[1050,11213,1825],{"class":1089},[1050,11215,11216],{"class":1052,"line":2635},[1050,11217,2034],{"class":1060},[1050,11219,11220,11223,11225,11227,11229,11231,11233,11235],{"class":1052,"line":2679},[1050,11221,11222],{"class":1060},"            posts2 ",[1050,11224,1318],{"class":1089},[1050,11226,11123],{"class":1060},[1050,11228,1090],{"class":1089},[1050,11230,11128],{"class":1331},[1050,11232,1197],{"class":1089},[1050,11234,1307],{"class":1306},[1050,11236,1436],{"class":1089},[1050,11238,11239],{"class":1052,"line":2684},[1050,11240,2034],{"class":1060},[1050,11242,11243,11246,11248,11250,11252,11254,11256,11258],{"class":1052,"line":2690},[1050,11244,11245],{"class":1060},"            hit_time ",[1050,11247,1318],{"class":1089},[1050,11249,1880],{"class":1060},[1050,11251,1090],{"class":1089},[1050,11253,1885],{"class":1331},[1050,11255,8758],{"class":1089},[1050,11257,3680],{"class":1635},[1050,11259,7721],{"class":1060},[1050,11261,11262,11265,11267,11269,11271,11273,11275,11277],{"class":1052,"line":2711},[1050,11263,11264],{"class":1060},"            hit_queries ",[1050,11266,1318],{"class":1089},[1050,11268,1670],{"class":1300},[1050,11270,1197],{"class":1089},[1050,11272,7700],{"class":1331},[1050,11274,1090],{"class":1089},[1050,11276,7705],{"class":1278},[1050,11278,1436],{"class":1089},[1050,11280,11281],{"class":1052,"line":2719},[1050,11282,1259],{"class":1060},[1050,11284,11285,11287,11289,11291,11294],{"class":1052,"line":2750},[1050,11286,4082],{"class":1300},[1050,11288,1197],{"class":1089},[1050,11290,1347],{"class":1189},[1050,11292,11293],{"class":1350},"\"Database Query Caching Performance:\"",[1050,11295,1436],{"class":1089},[1050,11297,11298,11300,11302,11304,11307,11309,11312,11314,11316,11318,11321,11323,11325,11327],{"class":1052,"line":2766},[1050,11299,4082],{"class":1300},[1050,11301,1197],{"class":1089},[1050,11303,1347],{"class":1189},[1050,11305,11306],{"class":1350},"\"Cache Miss: ",[1050,11308,1355],{"class":1354},[1050,11310,11311],{"class":1331},"miss_queries",[1050,11313,1361],{"class":1354},[1050,11315,9123],{"class":1350},[1050,11317,1355],{"class":1354},[1050,11319,11320],{"class":1331},"miss_time",[1050,11322,4156],{"class":1189},[1050,11324,1361],{"class":1354},[1050,11326,4161],{"class":1350},[1050,11328,1436],{"class":1089},[1050,11330,11331,11333,11335,11337,11340,11342,11345,11347,11349,11351,11354,11356,11358,11360],{"class":1052,"line":2780},[1050,11332,4082],{"class":1300},[1050,11334,1197],{"class":1089},[1050,11336,1347],{"class":1189},[1050,11338,11339],{"class":1350},"\"Cache Hit: ",[1050,11341,1355],{"class":1354},[1050,11343,11344],{"class":1331},"hit_queries",[1050,11346,1361],{"class":1354},[1050,11348,9123],{"class":1350},[1050,11350,1355],{"class":1354},[1050,11352,11353],{"class":1331},"hit_time",[1050,11355,4156],{"class":1189},[1050,11357,1361],{"class":1354},[1050,11359,4161],{"class":1350},[1050,11361,1436],{"class":1089},[1050,11363,11364],{"class":1052,"line":2792},[1050,11365,1259],{"class":1060},[1050,11367,11368],{"class":1052,"line":2808},[1050,11369,11370],{"class":1265},"        # Results should be identical\n",[1050,11372,11373,11375,11377,11379,11381,11383,11385,11388,11390,11392,11394,11397],{"class":1052,"line":2824},[1050,11374,1273],{"class":1272},[1050,11376,1090],{"class":1089},[1050,11378,10585],{"class":1331},[1050,11380,1197],{"class":1089},[1050,11382,3630],{"class":1300},[1050,11384,1197],{"class":1089},[1050,11386,11387],{"class":1331},"posts1",[1050,11389,5280],{"class":1089},[1050,11391,1670],{"class":1300},[1050,11393,1197],{"class":1089},[1050,11395,11396],{"class":1331},"posts2",[1050,11398,11399],{"class":1089},"))\n",[1050,11401,11402],{"class":1052,"line":2839},[1050,11403,1259],{"class":1060},[1050,11405,11406],{"class":1052,"line":2854},[1050,11407,11408],{"class":1265},"        # Cache hit should be much faster\n",[1050,11410,11411,11413,11415,11417,11419,11421,11423,11425,11427],{"class":1052,"line":2880},[1050,11412,1273],{"class":1272},[1050,11414,1090],{"class":1089},[1050,11416,10585],{"class":1331},[1050,11418,1197],{"class":1089},[1050,11420,11344],{"class":1331},[1050,11422,1101],{"class":1089},[1050,11424,2299],{"class":1306},[1050,11426,2619],{"class":1089},[1050,11428,11429],{"class":1265},"  # No database queries on cache hit\n",[1050,11431,11432,11434,11436,11438,11440,11442,11444,11447,11449,11451,11453],{"class":1052,"line":2886},[1050,11433,1273],{"class":1272},[1050,11435,1090],{"class":1089},[1050,11437,3986],{"class":1331},[1050,11439,1197],{"class":1089},[1050,11441,11353],{"class":1331},[1050,11443,1101],{"class":1089},[1050,11445,11446],{"class":1331}," miss_time ",[1050,11448,3645],{"class":1635},[1050,11450,4066],{"class":1306},[1050,11452,2619],{"class":1089},[1050,11454,11455],{"class":1265},"  # At least 10x faster\n",[1050,11457,11458],{"class":1052,"line":2891},[1050,11459,1224],{"class":1060},[1050,11461,11462,11464,11467,11469,11471],{"class":1052,"line":2911},[1050,11463,1230],{"class":1189},[1050,11465,11466],{"class":1233}," test_cache_invalidation_performance",[1050,11468,1197],{"class":1089},[1050,11470,1240],{"class":1239},[1050,11472,1204],{"class":1089},[1050,11474,11475,11477,11480],{"class":1052,"line":2916},[1050,11476,1248],{"class":1210},[1050,11478,11479],{"class":1214},"Test cache invalidation strategies",[1050,11481,1218],{"class":1210},[1050,11483,11484],{"class":1052,"line":2935},[1050,11485,1259],{"class":1060},[1050,11487,11488,11490,11492,11494,11496,11498,11500,11502],{"class":1052,"line":2945},[1050,11489,1453],{"class":1056},[1050,11491,1112],{"class":1060},[1050,11493,1090],{"class":1089},[1050,11495,9271],{"class":1060},[1050,11497,1090],{"class":1089},[1050,11499,10030],{"class":1060},[1050,11501,1057],{"class":1056},[1050,11503,10035],{"class":1060},[1050,11505,11506],{"class":1052,"line":2950},[1050,11507,1259],{"class":1060},[1050,11509,11510],{"class":1052,"line":2962},[1050,11511,11512],{"class":1265},"        # Cache some data\n",[1050,11514,11515,11517,11519,11521,11523,11525,11528,11530,11532,11534,11537,11539,11541,11543],{"class":1052,"line":2988},[1050,11516,10040],{"class":1060},[1050,11518,1090],{"class":1089},[1050,11520,11018],{"class":1331},[1050,11522,1197],{"class":1089},[1050,11524,1364],{"class":1401},[1050,11526,11527],{"class":1350},"test_key_1",[1050,11529,1364],{"class":1401},[1050,11531,1101],{"class":1089},[1050,11533,1915],{"class":1401},[1050,11535,11536],{"class":1350},"value_1",[1050,11538,1364],{"class":1401},[1050,11540,1101],{"class":1089},[1050,11542,11031],{"class":1306},[1050,11544,1436],{"class":1089},[1050,11546,11547,11549,11551,11553,11555,11557,11560,11562,11564,11566,11569,11571,11573,11575],{"class":1052,"line":2993},[1050,11548,10040],{"class":1060},[1050,11550,1090],{"class":1089},[1050,11552,11018],{"class":1331},[1050,11554,1197],{"class":1089},[1050,11556,1364],{"class":1401},[1050,11558,11559],{"class":1350},"test_key_2",[1050,11561,1364],{"class":1401},[1050,11563,1101],{"class":1089},[1050,11565,1915],{"class":1401},[1050,11567,11568],{"class":1350},"value_2",[1050,11570,1364],{"class":1401},[1050,11572,1101],{"class":1089},[1050,11574,11031],{"class":1306},[1050,11576,1436],{"class":1089},[1050,11578,11579,11581,11583,11585,11587,11589,11592,11594,11596,11598,11601,11603,11605,11607],{"class":1052,"line":2999},[1050,11580,10040],{"class":1060},[1050,11582,1090],{"class":1089},[1050,11584,11018],{"class":1331},[1050,11586,1197],{"class":1089},[1050,11588,1364],{"class":1401},[1050,11590,11591],{"class":1350},"test_key_3",[1050,11593,1364],{"class":1401},[1050,11595,1101],{"class":1089},[1050,11597,1915],{"class":1401},[1050,11599,11600],{"class":1350},"value_3",[1050,11602,1364],{"class":1401},[1050,11604,1101],{"class":1089},[1050,11606,11031],{"class":1306},[1050,11608,1436],{"class":1089},[1050,11610,11611],{"class":1052,"line":3034},[1050,11612,1259],{"class":1060},[1050,11614,11615],{"class":1052,"line":3074},[1050,11616,11617],{"class":1265},"        # Test individual key deletion\n",[1050,11619,11620,11622,11624,11626,11628,11630],{"class":1052,"line":3110},[1050,11621,1875],{"class":1060},[1050,11623,1318],{"class":1089},[1050,11625,1880],{"class":1060},[1050,11627,1090],{"class":1089},[1050,11629,1885],{"class":1331},[1050,11631,1825],{"class":1089},[1050,11633,11634,11636,11638,11640,11642,11644,11646,11648],{"class":1052,"line":3115},[1050,11635,10040],{"class":1060},[1050,11637,1090],{"class":1089},[1050,11639,8824],{"class":1331},[1050,11641,1197],{"class":1089},[1050,11643,1364],{"class":1401},[1050,11645,11527],{"class":1350},[1050,11647,1364],{"class":1401},[1050,11649,1436],{"class":1089},[1050,11651,11652,11655,11657,11659,11661,11663,11665,11667],{"class":1052,"line":3121},[1050,11653,11654],{"class":1060},"        individual_delete_time ",[1050,11656,1318],{"class":1089},[1050,11658,1880],{"class":1060},[1050,11660,1090],{"class":1089},[1050,11662,1885],{"class":1331},[1050,11664,8758],{"class":1089},[1050,11666,3680],{"class":1635},[1050,11668,7721],{"class":1060},[1050,11670,11671],{"class":1052,"line":3131},[1050,11672,1259],{"class":1060},[1050,11674,11675],{"class":1052,"line":3152},[1050,11676,11677],{"class":1265},"        # Test pattern-based deletion (if supported)\n",[1050,11679,11680,11682,11684,11686,11688,11690],{"class":1052,"line":3172},[1050,11681,1875],{"class":1060},[1050,11683,1318],{"class":1089},[1050,11685,1880],{"class":1060},[1050,11687,1090],{"class":1089},[1050,11689,1885],{"class":1331},[1050,11691,1825],{"class":1089},[1050,11693,11694,11696,11698,11701,11704,11706,11708,11710,11712,11714,11716,11718],{"class":1052,"line":3192},[1050,11695,10040],{"class":1060},[1050,11697,1090],{"class":1089},[1050,11699,11700],{"class":1331},"delete_many",[1050,11702,11703],{"class":1089},"([",[1050,11705,1364],{"class":1401},[1050,11707,11559],{"class":1350},[1050,11709,1364],{"class":1401},[1050,11711,1101],{"class":1089},[1050,11713,1915],{"class":1401},[1050,11715,11591],{"class":1350},[1050,11717,1364],{"class":1401},[1050,11719,10999],{"class":1089},[1050,11721,11722,11725,11727,11729,11731,11733,11735,11737],{"class":1052,"line":3230},[1050,11723,11724],{"class":1060},"        batch_delete_time ",[1050,11726,1318],{"class":1089},[1050,11728,1880],{"class":1060},[1050,11730,1090],{"class":1089},[1050,11732,1885],{"class":1331},[1050,11734,8758],{"class":1089},[1050,11736,3680],{"class":1635},[1050,11738,7721],{"class":1060},[1050,11740,11741],{"class":1052,"line":3235},[1050,11742,1259],{"class":1060},[1050,11744,11745,11747,11749,11751,11754],{"class":1052,"line":3241},[1050,11746,4082],{"class":1300},[1050,11748,1197],{"class":1089},[1050,11750,1347],{"class":1189},[1050,11752,11753],{"class":1350},"\"Cache Invalidation Performance:\"",[1050,11755,1436],{"class":1089},[1050,11757,11758,11760,11762,11764,11767,11769,11772,11775,11777,11779],{"class":1052,"line":3268},[1050,11759,4082],{"class":1300},[1050,11761,1197],{"class":1089},[1050,11763,1347],{"class":1189},[1050,11765,11766],{"class":1350},"\"Individual Delete: ",[1050,11768,1355],{"class":1354},[1050,11770,11771],{"class":1331},"individual_delete_time",[1050,11773,11774],{"class":1189},":.6f",[1050,11776,1361],{"class":1354},[1050,11778,4161],{"class":1350},[1050,11780,1436],{"class":1089},[1050,11782,11783,11785,11787,11789,11792,11794,11797,11799,11801,11803],{"class":1052,"line":3289},[1050,11784,4082],{"class":1300},[1050,11786,1197],{"class":1089},[1050,11788,1347],{"class":1189},[1050,11790,11791],{"class":1350},"\"Batch Delete: ",[1050,11793,1355],{"class":1354},[1050,11795,11796],{"class":1331},"batch_delete_time",[1050,11798,11774],{"class":1189},[1050,11800,1361],{"class":1354},[1050,11802,4161],{"class":1350},[1050,11804,1436],{"class":1089},[1050,11806,11807],{"class":1052,"line":3310},[1050,11808,1259],{"class":1060},[1050,11810,11811],{"class":1052,"line":3335},[1050,11812,11813],{"class":1265},"        # Verify deletions\n",[1050,11815,11816,11818,11820,11823,11825,11828,11830,11832,11834,11836,11838,11840],{"class":1052,"line":3340},[1050,11817,1273],{"class":1272},[1050,11819,1090],{"class":1089},[1050,11821,11822],{"class":1331},"assertIsNone",[1050,11824,1197],{"class":1089},[1050,11826,11827],{"class":1331},"cache",[1050,11829,1090],{"class":1089},[1050,11831,1937],{"class":1331},[1050,11833,1197],{"class":1089},[1050,11835,1364],{"class":1401},[1050,11837,11527],{"class":1350},[1050,11839,1364],{"class":1401},[1050,11841,11399],{"class":1089},[1050,11843,11844,11846,11848,11850,11852,11854,11856,11858,11860,11862,11864,11866],{"class":1052,"line":3346},[1050,11845,1273],{"class":1272},[1050,11847,1090],{"class":1089},[1050,11849,11822],{"class":1331},[1050,11851,1197],{"class":1089},[1050,11853,11827],{"class":1331},[1050,11855,1090],{"class":1089},[1050,11857,1937],{"class":1331},[1050,11859,1197],{"class":1089},[1050,11861,1364],{"class":1401},[1050,11863,11559],{"class":1350},[1050,11865,1364],{"class":1401},[1050,11867,11399],{"class":1089},[1050,11869,11870,11872,11874,11876,11878,11880,11882,11884,11886,11888,11890,11892],{"class":1052,"line":3376},[1050,11871,1273],{"class":1272},[1050,11873,1090],{"class":1089},[1050,11875,11822],{"class":1331},[1050,11877,1197],{"class":1089},[1050,11879,11827],{"class":1331},[1050,11881,1090],{"class":1089},[1050,11883,1937],{"class":1331},[1050,11885,1197],{"class":1089},[1050,11887,1364],{"class":1401},[1050,11889,11591],{"class":1350},[1050,11891,1364],{"class":1401},[1050,11893,11399],{"class":1089},[1050,11895,11896],{"class":1052,"line":3405},[1050,11897,1224],{"class":1060},[1050,11899,11900,11902,11905,11907,11909],{"class":1052,"line":3410},[1050,11901,1230],{"class":1189},[1050,11903,11904],{"class":1233}," test_cache_memory_usage",[1050,11906,1197],{"class":1089},[1050,11908,1240],{"class":1239},[1050,11910,1204],{"class":1089},[1050,11912,11913,11915,11918],{"class":1052,"line":3416},[1050,11914,1248],{"class":1210},[1050,11916,11917],{"class":1214},"Test cache memory usage patterns",[1050,11919,1218],{"class":1210},[1050,11921,11922],{"class":1052,"line":3457},[1050,11923,1259],{"class":1060},[1050,11925,11926,11928,11930,11932,11934,11936,11938,11940],{"class":1052,"line":3462},[1050,11927,1453],{"class":1056},[1050,11929,1112],{"class":1060},[1050,11931,1090],{"class":1089},[1050,11933,9271],{"class":1060},[1050,11935,1090],{"class":1089},[1050,11937,10030],{"class":1060},[1050,11939,1057],{"class":1056},[1050,11941,10035],{"class":1060},[1050,11943,11944,11946],{"class":1052,"line":3468},[1050,11945,6180],{"class":1056},[1050,11947,11948],{"class":1060}," sys\n",[1050,11950,11951],{"class":1052,"line":3518},[1050,11952,1259],{"class":1060},[1050,11954,11955],{"class":1052,"line":3543},[1050,11956,11957],{"class":1265},"        # Clear cache and measure baseline\n",[1050,11959,11960,11962,11964,11966],{"class":1052,"line":3549},[1050,11961,10040],{"class":1060},[1050,11963,1090],{"class":1089},[1050,11965,7549],{"class":1331},[1050,11967,1825],{"class":1089},[1050,11969,11970],{"class":1052,"line":3554},[1050,11971,1259],{"class":1060},[1050,11973,11974],{"class":1052,"line":3562},[1050,11975,11976],{"class":1265},"        # Store large amounts of data in cache\n",[1050,11978,11979,11982,11984,11986,11989,11991,11993,11996],{"class":1052,"line":3567},[1050,11980,11981],{"class":1060},"        large_data ",[1050,11983,1318],{"class":1089},[1050,11985,1915],{"class":1401},[1050,11987,11988],{"class":1350},"x",[1050,11990,1364],{"class":1401},[1050,11992,1636],{"class":1635},[1050,11994,11995],{"class":1306}," 10000",[1050,11997,11998],{"class":1265},"  # 10KB string\n",[1050,12000,12001],{"class":1052,"line":3589},[1050,12002,1259],{"class":1060},[1050,12004,12005,12007,12009,12011,12013,12015],{"class":1052,"line":3599},[1050,12006,1875],{"class":1060},[1050,12008,1318],{"class":1089},[1050,12010,1880],{"class":1060},[1050,12012,1090],{"class":1089},[1050,12014,1885],{"class":1331},[1050,12016,1825],{"class":1089},[1050,12018,12019],{"class":1052,"line":3617},[1050,12020,1259],{"class":1060},[1050,12022,12023],{"class":1052,"line":3652},[1050,12024,12025],{"class":1265},"        # Cache many large objects\n",[1050,12027,12028,12030,12032,12034,12036,12038,12040],{"class":1052,"line":3688},[1050,12029,1291],{"class":1056},[1050,12031,1294],{"class":1060},[1050,12033,1297],{"class":1056},[1050,12035,1301],{"class":1300},[1050,12037,1197],{"class":1089},[1050,12039,1565],{"class":1306},[1050,12041,1204],{"class":1089},[1050,12043,12044,12047,12049,12051,12053,12055,12058,12060,12062,12064,12066,12068,12071,12073,12075],{"class":1052,"line":3693},[1050,12045,12046],{"class":1060},"            cache",[1050,12048,1090],{"class":1089},[1050,12050,11018],{"class":1331},[1050,12052,1197],{"class":1089},[1050,12054,1347],{"class":1189},[1050,12056,12057],{"class":1350},"'large_key_",[1050,12059,1355],{"class":1354},[1050,12061,1358],{"class":1331},[1050,12063,1361],{"class":1354},[1050,12065,1364],{"class":1350},[1050,12067,1101],{"class":1089},[1050,12069,12070],{"class":1331}," large_data",[1050,12072,1101],{"class":1089},[1050,12074,11031],{"class":1306},[1050,12076,1436],{"class":1089},[1050,12078,12079],{"class":1052,"line":3711},[1050,12080,1259],{"class":1060},[1050,12082,12083,12086,12088,12090,12092,12094,12096,12098],{"class":1052,"line":3721},[1050,12084,12085],{"class":1060},"        cache_write_time ",[1050,12087,1318],{"class":1089},[1050,12089,1880],{"class":1060},[1050,12091,1090],{"class":1089},[1050,12093,1885],{"class":1331},[1050,12095,8758],{"class":1089},[1050,12097,3680],{"class":1635},[1050,12099,7721],{"class":1060},[1050,12101,12102],{"class":1052,"line":3732},[1050,12103,1259],{"class":1060},[1050,12105,12106],{"class":1052,"line":3746},[1050,12107,12108],{"class":1265},"        # Read from cache\n",[1050,12110,12111,12113,12115,12117,12119,12121],{"class":1052,"line":3767},[1050,12112,1875],{"class":1060},[1050,12114,1318],{"class":1089},[1050,12116,1880],{"class":1060},[1050,12118,1090],{"class":1089},[1050,12120,1885],{"class":1331},[1050,12122,1825],{"class":1089},[1050,12124,12125],{"class":1052,"line":3804},[1050,12126,1259],{"class":1060},[1050,12128,12129,12132,12134],{"class":1052,"line":3812},[1050,12130,12131],{"class":1060},"        retrieved_data ",[1050,12133,1318],{"class":1089},[1050,12135,1285],{"class":1089},[1050,12137,12138,12140,12142,12144,12146,12148,12150],{"class":1052,"line":3817},[1050,12139,1291],{"class":1056},[1050,12141,1294],{"class":1060},[1050,12143,1297],{"class":1056},[1050,12145,1301],{"class":1300},[1050,12147,1197],{"class":1089},[1050,12149,1565],{"class":1306},[1050,12151,1204],{"class":1089},[1050,12153,12154,12157,12159,12161,12163,12165,12167,12169,12171,12173,12175,12177,12179],{"class":1052,"line":3832},[1050,12155,12156],{"class":1060},"            data ",[1050,12158,1318],{"class":1089},[1050,12160,10866],{"class":1060},[1050,12162,1090],{"class":1089},[1050,12164,1937],{"class":1331},[1050,12166,1197],{"class":1089},[1050,12168,1347],{"class":1189},[1050,12170,12057],{"class":1350},[1050,12172,1355],{"class":1354},[1050,12174,1358],{"class":1331},[1050,12176,1361],{"class":1354},[1050,12178,1364],{"class":1350},[1050,12180,1436],{"class":1089},[1050,12182,12183,12186,12188,12190,12192,12194],{"class":1052,"line":3842},[1050,12184,12185],{"class":1060},"            retrieved_data",[1050,12187,1090],{"class":1089},[1050,12189,1428],{"class":1331},[1050,12191,1197],{"class":1089},[1050,12193,3612],{"class":1331},[1050,12195,1436],{"class":1089},[1050,12197,12198],{"class":1052,"line":3847},[1050,12199,1259],{"class":1060},[1050,12201,12202,12205,12207,12209,12211,12213,12215,12217],{"class":1052,"line":3861},[1050,12203,12204],{"class":1060},"        cache_read_time ",[1050,12206,1318],{"class":1089},[1050,12208,1880],{"class":1060},[1050,12210,1090],{"class":1089},[1050,12212,1885],{"class":1331},[1050,12214,8758],{"class":1089},[1050,12216,3680],{"class":1635},[1050,12218,7721],{"class":1060},[1050,12220,12221],{"class":1052,"line":3871},[1050,12222,1259],{"class":1060},[1050,12224,12225,12227,12229,12231,12234],{"class":1052,"line":3876},[1050,12226,4082],{"class":1300},[1050,12228,1197],{"class":1089},[1050,12230,1347],{"class":1189},[1050,12232,12233],{"class":1350},"\"Cache Memory Usage Performance:\"",[1050,12235,1436],{"class":1089},[1050,12237,12238,12240,12242,12244,12247,12249,12252,12254,12256,12258],{"class":1052,"line":3892},[1050,12239,4082],{"class":1300},[1050,12241,1197],{"class":1089},[1050,12243,1347],{"class":1189},[1050,12245,12246],{"class":1350},"\"Write 100 x 10KB objects: ",[1050,12248,1355],{"class":1354},[1050,12250,12251],{"class":1331},"cache_write_time",[1050,12253,4156],{"class":1189},[1050,12255,1361],{"class":1354},[1050,12257,4161],{"class":1350},[1050,12259,1436],{"class":1089},[1050,12261,12262,12264,12266,12268,12271,12273,12276,12278,12280,12282],{"class":1052,"line":3908},[1050,12263,4082],{"class":1300},[1050,12265,1197],{"class":1089},[1050,12267,1347],{"class":1189},[1050,12269,12270],{"class":1350},"\"Read 100 x 10KB objects: ",[1050,12272,1355],{"class":1354},[1050,12274,12275],{"class":1331},"cache_read_time",[1050,12277,4156],{"class":1189},[1050,12279,1361],{"class":1354},[1050,12281,4161],{"class":1350},[1050,12283,1436],{"class":1089},[1050,12285,12286],{"class":1052,"line":3921},[1050,12287,1259],{"class":1060},[1050,12289,12290],{"class":1052,"line":3932},[1050,12291,12292],{"class":1265},"        # Verify all data was cached and retrieved\n",[1050,12294,12295,12297,12299,12301,12303,12305,12307,12310,12312,12314],{"class":1052,"line":3938},[1050,12296,1273],{"class":1272},[1050,12298,1090],{"class":1089},[1050,12300,10585],{"class":1331},[1050,12302,1197],{"class":1089},[1050,12304,3630],{"class":1300},[1050,12306,1197],{"class":1089},[1050,12308,12309],{"class":1331},"retrieved_data",[1050,12311,5280],{"class":1089},[1050,12313,3225],{"class":1306},[1050,12315,1436],{"class":1089},[1050,12317,12318,12320,12322,12325,12327,12329,12331,12334,12336,12339,12341,12343,12345,12348],{"class":1052,"line":3943},[1050,12319,1273],{"class":1272},[1050,12321,1090],{"class":1089},[1050,12323,12324],{"class":1331},"assertTrue",[1050,12326,1197],{"class":1089},[1050,12328,7597],{"class":1300},[1050,12330,1197],{"class":1089},[1050,12332,12333],{"class":1331},"data ",[1050,12335,1912],{"class":1635},[1050,12337,12338],{"class":1331}," large_data ",[1050,12340,3047],{"class":1056},[1050,12342,1985],{"class":1331},[1050,12344,1297],{"class":1056},[1050,12346,12347],{"class":1331}," retrieved_data",[1050,12349,11399],{"class":1089},[1050,12351,12352],{"class":1052,"line":3949},[1050,12353,1259],{"class":1060},[1050,12355,12356],{"class":1052,"line":3979},[1050,12357,12358],{"class":1265},"        # Cache operations should be fast\n",[1050,12360,12361,12363,12365,12367,12369,12371,12373,12376],{"class":1052,"line":4011},[1050,12362,1273],{"class":1272},[1050,12364,1090],{"class":1089},[1050,12366,3986],{"class":1331},[1050,12368,1197],{"class":1089},[1050,12370,12251],{"class":1331},[1050,12372,1101],{"class":1089},[1050,12374,12375],{"class":1306}," 1.0",[1050,12377,1436],{"class":1089},[1050,12379,12380,12382,12384,12386,12388,12390,12392,12395],{"class":1052,"line":4042},[1050,12381,1273],{"class":1272},[1050,12383,1090],{"class":1089},[1050,12385,3986],{"class":1331},[1050,12387,1197],{"class":1089},[1050,12389,12275],{"class":1331},[1050,12391,1101],{"class":1089},[1050,12393,12394],{"class":1306}," 0.5",[1050,12396,1436],{"class":1089},[1030,12398,12400],{"id":12399},"frontend-performance-testing","Frontend Performance Testing",[1035,12402,12404],{"id":12403},"static-asset-performance","Static Asset Performance",[1040,12406,12408],{"className":1042,"code":12407,"language":1044,"meta":1045,"style":1045},"class FrontendPerformanceTests(TestCase):\n    \"\"\"Test frontend performance aspects\"\"\"\n    \n    def test_static_file_serving_performance(self):\n        \"\"\"Test static file serving performance\"\"\"\n        \n        # Test CSS file serving\n        css_start = time.time()\n        css_response = self.client.get('/static/css/style.css')\n        css_time = time.time() - css_start\n        \n        # Test JavaScript file serving\n        js_start = time.time()\n        js_response = self.client.get('/static/js/app.js')\n        js_time = time.time() - js_start\n        \n        # Test image file serving\n        img_start = time.time()\n        img_response = self.client.get('/static/images/logo.png')\n        img_time = time.time() - img_start\n        \n        print(f\"Static File Serving Performance:\")\n        print(f\"CSS: {css_time:.3f}s ({len(css_response.content)} bytes)\")\n        print(f\"JS: {js_time:.3f}s ({len(js_response.content)} bytes)\")\n        print(f\"Image: {img_time:.3f}s ({len(img_response.content)} bytes)\")\n        \n        # Static files should serve quickly\n        # Note: These tests assume static files exist\n        if css_response.status_code == 200:\n            self.assertLess(css_time, 0.1)\n        if js_response.status_code == 200:\n            self.assertLess(js_time, 0.1)\n        if img_response.status_code == 200:\n            self.assertLess(img_time, 0.2)\n    \n    def test_page_size_optimization(self):\n        \"\"\"Test page size and compression\"\"\"\n        \n        # Test main pages\n        pages = [\n            ('/', 'Homepage'),\n            ('/blog/', 'Blog List'),\n            ('/about/', 'About Page'),\n        ]\n        \n        for url, name in pages:\n            response = self.client.get(url)\n            \n            if response.status_code == 200:\n                content_length = len(response.content)\n                \n                print(f\"{name} Size: {content_length:,} bytes\")\n                \n                # Pages should be reasonably sized\n                self.assertLess(content_length, 500000)  # \u003C 500KB\n                \n                # Check for compression headers (if enabled)\n                if 'gzip' in response.get('Content-Encoding', ''):\n                    print(f\"{name} is gzipped\")\n    \n    def test_template_rendering_performance(self):\n        \"\"\"Test template rendering performance\"\"\"\n        \n        from django.template import Template, Context\n        \n        # Test simple template\n        simple_template = Template(\"\"\"\n        \u003Chtml>\n        \u003Chead>\u003Ctitle>{{ title }}\u003C/title>\u003C/head>\n        \u003Cbody>\n            \u003Ch1>{{ heading }}\u003C/h1>\n            \u003Cp>{{ content }}\u003C/p>\n        \u003C/body>\n        \u003C/html>\n        \"\"\")\n        \n        simple_context = Context({\n            'title': 'Test Page',\n            'heading': 'Welcome',\n            'content': 'This is test content.'\n        })\n        \n        start_time = time.time()\n        for _ in range(1000):\n            rendered = simple_template.render(simple_context)\n        simple_time = time.time() - start_time\n        \n        # Test complex template with loops\n        complex_template = Template(\"\"\"\n        \u003Chtml>\n        \u003Chead>\u003Ctitle>{{ title }}\u003C/title>\u003C/head>\n        \u003Cbody>\n            \u003Ch1>{{ heading }}\u003C/h1>\n            {% for item in items %}\n                \u003Cdiv class=\"item\">\n                    \u003Ch3>{{ item.title }}\u003C/h3>\n                    \u003Cp>{{ item.content|truncatewords:20 }}\u003C/p>\n                    \u003Csmall>By {{ item.author }} on {{ item.date|date:\"F j, Y\" }}\u003C/small>\n                \u003C/div>\n            {% endfor %}\n        \u003C/body>\n        \u003C/html>\n        \"\"\")\n        \n        complex_context = Context({\n            'title': 'Complex Page',\n            'heading': 'Items List',\n            'items': [\n                {\n                    'title': f'Item {i}',\n                    'content': f'Content for item {i}. ' * 20,\n                    'author': f'Author {i}',\n                    'date': time.time()\n                }\n                for i in range(50)\n            ]\n        })\n        \n        start_time = time.time()\n        for _ in range(100):\n            rendered = complex_template.render(complex_context)\n        complex_time = time.time() - start_time\n        \n        print(f\"Template Rendering Performance:\")\n        print(f\"Simple Template (1000x): {simple_time:.3f}s\")\n        print(f\"Complex Template (100x): {complex_time:.3f}s\")\n        \n        # Template rendering should be fast\n        self.assertLess(simple_time, 1.0)\n        self.assertLess(complex_time, 2.0)\n",[1047,12409,12410,12423,12432,12436,12449,12458,12462,12467,12482,12510,12530,12534,12539,12554,12582,12602,12606,12611,12626,12654,12674,12678,12691,12736,12779,12822,12826,12831,12836,12854,12873,12890,12908,12925,12944,12948,12961,12970,12974,12979,12988,13009,13030,13052,13056,13060,13078,13101,13105,13121,13140,13144,13177,13181,13186,13209,13213,13218,13254,13276,13280,13293,13302,13306,13327,13331,13336,13349,13354,13371,13376,13391,13406,13411,13416,13422,13426,13438,13458,13478,13495,13500,13504,13518,13534,13556,13575,13579,13584,13597,13601,13613,13617,13629,13634,13639,13644,13649,13654,13659,13664,13668,13672,13678,13682,13693,13712,13731,13743,13748,13773,13802,13827,13846,13850,13866,13871,13875,13879,13893,13909,13929,13948,13952,13965,13989,14013,14017,14022,14040],{"__ignoreMap":1045},[1050,12411,12412,12414,12417,12419,12421],{"class":1052,"line":1053},[1050,12413,1190],{"class":1189},[1050,12415,12416],{"class":1193}," FrontendPerformanceTests",[1050,12418,1197],{"class":1089},[1050,12420,1201],{"class":1200},[1050,12422,1204],{"class":1089},[1050,12424,12425,12427,12430],{"class":1052,"line":1064},[1050,12426,1211],{"class":1210},[1050,12428,12429],{"class":1214},"Test frontend performance aspects",[1050,12431,1218],{"class":1210},[1050,12433,12434],{"class":1052,"line":1072},[1050,12435,1224],{"class":1060},[1050,12437,12438,12440,12443,12445,12447],{"class":1052,"line":1080},[1050,12439,1230],{"class":1189},[1050,12441,12442],{"class":1233}," test_static_file_serving_performance",[1050,12444,1197],{"class":1089},[1050,12446,1240],{"class":1239},[1050,12448,1204],{"class":1089},[1050,12450,12451,12453,12456],{"class":1052,"line":1107},[1050,12452,1248],{"class":1210},[1050,12454,12455],{"class":1214},"Test static file serving performance",[1050,12457,1218],{"class":1210},[1050,12459,12460],{"class":1052,"line":1130},[1050,12461,1259],{"class":1060},[1050,12463,12464],{"class":1052,"line":1152},[1050,12465,12466],{"class":1265},"        # Test CSS file serving\n",[1050,12468,12469,12472,12474,12476,12478,12480],{"class":1052,"line":1179},[1050,12470,12471],{"class":1060},"        css_start ",[1050,12473,1318],{"class":1089},[1050,12475,1880],{"class":1060},[1050,12477,1090],{"class":1089},[1050,12479,1885],{"class":1331},[1050,12481,1825],{"class":1089},[1050,12483,12484,12487,12489,12491,12493,12495,12497,12499,12501,12503,12506,12508],{"class":1052,"line":1186},[1050,12485,12486],{"class":1060},"        css_response ",[1050,12488,1318],{"class":1089},[1050,12490,2481],{"class":1272},[1050,12492,1090],{"class":1089},[1050,12494,10400],{"class":1278},[1050,12496,1090],{"class":1089},[1050,12498,1937],{"class":1331},[1050,12500,1197],{"class":1089},[1050,12502,1364],{"class":1401},[1050,12504,12505],{"class":1350},"/static/css/style.css",[1050,12507,1364],{"class":1401},[1050,12509,1436],{"class":1089},[1050,12511,12512,12515,12517,12519,12521,12523,12525,12527],{"class":1052,"line":1207},[1050,12513,12514],{"class":1060},"        css_time ",[1050,12516,1318],{"class":1089},[1050,12518,1880],{"class":1060},[1050,12520,1090],{"class":1089},[1050,12522,1885],{"class":1331},[1050,12524,8758],{"class":1089},[1050,12526,3680],{"class":1635},[1050,12528,12529],{"class":1060}," css_start\n",[1050,12531,12532],{"class":1052,"line":1221},[1050,12533,1259],{"class":1060},[1050,12535,12536],{"class":1052,"line":1227},[1050,12537,12538],{"class":1265},"        # Test JavaScript file serving\n",[1050,12540,12541,12544,12546,12548,12550,12552],{"class":1052,"line":1245},[1050,12542,12543],{"class":1060},"        js_start ",[1050,12545,1318],{"class":1089},[1050,12547,1880],{"class":1060},[1050,12549,1090],{"class":1089},[1050,12551,1885],{"class":1331},[1050,12553,1825],{"class":1089},[1050,12555,12556,12559,12561,12563,12565,12567,12569,12571,12573,12575,12578,12580],{"class":1052,"line":1256},[1050,12557,12558],{"class":1060},"        js_response ",[1050,12560,1318],{"class":1089},[1050,12562,2481],{"class":1272},[1050,12564,1090],{"class":1089},[1050,12566,10400],{"class":1278},[1050,12568,1090],{"class":1089},[1050,12570,1937],{"class":1331},[1050,12572,1197],{"class":1089},[1050,12574,1364],{"class":1401},[1050,12576,12577],{"class":1350},"/static/js/app.js",[1050,12579,1364],{"class":1401},[1050,12581,1436],{"class":1089},[1050,12583,12584,12587,12589,12591,12593,12595,12597,12599],{"class":1052,"line":1262},[1050,12585,12586],{"class":1060},"        js_time ",[1050,12588,1318],{"class":1089},[1050,12590,1880],{"class":1060},[1050,12592,1090],{"class":1089},[1050,12594,1885],{"class":1331},[1050,12596,8758],{"class":1089},[1050,12598,3680],{"class":1635},[1050,12600,12601],{"class":1060}," js_start\n",[1050,12603,12604],{"class":1052,"line":1269},[1050,12605,1259],{"class":1060},[1050,12607,12608],{"class":1052,"line":1288},[1050,12609,12610],{"class":1265},"        # Test image file serving\n",[1050,12612,12613,12616,12618,12620,12622,12624],{"class":1052,"line":1312},[1050,12614,12615],{"class":1060},"        img_start ",[1050,12617,1318],{"class":1089},[1050,12619,1880],{"class":1060},[1050,12621,1090],{"class":1089},[1050,12623,1885],{"class":1331},[1050,12625,1825],{"class":1089},[1050,12627,12628,12631,12633,12635,12637,12639,12641,12643,12645,12647,12650,12652],{"class":1052,"line":1338},[1050,12629,12630],{"class":1060},"        img_response ",[1050,12632,1318],{"class":1089},[1050,12634,2481],{"class":1272},[1050,12636,1090],{"class":1089},[1050,12638,10400],{"class":1278},[1050,12640,1090],{"class":1089},[1050,12642,1937],{"class":1331},[1050,12644,1197],{"class":1089},[1050,12646,1364],{"class":1401},[1050,12648,12649],{"class":1350},"/static/images/logo.png",[1050,12651,1364],{"class":1401},[1050,12653,1436],{"class":1089},[1050,12655,12656,12659,12661,12663,12665,12667,12669,12671],{"class":1052,"line":1370},[1050,12657,12658],{"class":1060},"        img_time ",[1050,12660,1318],{"class":1089},[1050,12662,1880],{"class":1060},[1050,12664,1090],{"class":1089},[1050,12666,1885],{"class":1331},[1050,12668,8758],{"class":1089},[1050,12670,3680],{"class":1635},[1050,12672,12673],{"class":1060}," img_start\n",[1050,12675,12676],{"class":1052,"line":1393},[1050,12677,1259],{"class":1060},[1050,12679,12680,12682,12684,12686,12689],{"class":1052,"line":1410},[1050,12681,4082],{"class":1300},[1050,12683,1197],{"class":1089},[1050,12685,1347],{"class":1189},[1050,12687,12688],{"class":1350},"\"Static File Serving Performance:\"",[1050,12690,1436],{"class":1089},[1050,12692,12693,12695,12697,12699,12702,12704,12707,12709,12711,12714,12716,12718,12720,12723,12725,12727,12729,12731,12734],{"class":1052,"line":1416},[1050,12694,4082],{"class":1300},[1050,12696,1197],{"class":1089},[1050,12698,1347],{"class":1189},[1050,12700,12701],{"class":1350},"\"CSS: ",[1050,12703,1355],{"class":1354},[1050,12705,12706],{"class":1331},"css_time",[1050,12708,4156],{"class":1189},[1050,12710,1361],{"class":1354},[1050,12712,12713],{"class":1350},"s (",[1050,12715,1355],{"class":1354},[1050,12717,3630],{"class":1300},[1050,12719,1197],{"class":1089},[1050,12721,12722],{"class":1331},"css_response",[1050,12724,1090],{"class":1089},[1050,12726,2166],{"class":1278},[1050,12728,2619],{"class":1089},[1050,12730,1361],{"class":1354},[1050,12732,12733],{"class":1350}," bytes)\"",[1050,12735,1436],{"class":1089},[1050,12737,12738,12740,12742,12744,12747,12749,12752,12754,12756,12758,12760,12762,12764,12767,12769,12771,12773,12775,12777],{"class":1052,"line":1439},[1050,12739,4082],{"class":1300},[1050,12741,1197],{"class":1089},[1050,12743,1347],{"class":1189},[1050,12745,12746],{"class":1350},"\"JS: ",[1050,12748,1355],{"class":1354},[1050,12750,12751],{"class":1331},"js_time",[1050,12753,4156],{"class":1189},[1050,12755,1361],{"class":1354},[1050,12757,12713],{"class":1350},[1050,12759,1355],{"class":1354},[1050,12761,3630],{"class":1300},[1050,12763,1197],{"class":1089},[1050,12765,12766],{"class":1331},"js_response",[1050,12768,1090],{"class":1089},[1050,12770,2166],{"class":1278},[1050,12772,2619],{"class":1089},[1050,12774,1361],{"class":1354},[1050,12776,12733],{"class":1350},[1050,12778,1436],{"class":1089},[1050,12780,12781,12783,12785,12787,12790,12792,12795,12797,12799,12801,12803,12805,12807,12810,12812,12814,12816,12818,12820],{"class":1052,"line":1444},[1050,12782,4082],{"class":1300},[1050,12784,1197],{"class":1089},[1050,12786,1347],{"class":1189},[1050,12788,12789],{"class":1350},"\"Image: ",[1050,12791,1355],{"class":1354},[1050,12793,12794],{"class":1331},"img_time",[1050,12796,4156],{"class":1189},[1050,12798,1361],{"class":1354},[1050,12800,12713],{"class":1350},[1050,12802,1355],{"class":1354},[1050,12804,3630],{"class":1300},[1050,12806,1197],{"class":1089},[1050,12808,12809],{"class":1331},"img_response",[1050,12811,1090],{"class":1089},[1050,12813,2166],{"class":1278},[1050,12815,2619],{"class":1089},[1050,12817,1361],{"class":1354},[1050,12819,12733],{"class":1350},[1050,12821,1436],{"class":1089},[1050,12823,12824],{"class":1052,"line":1450},[1050,12825,1259],{"class":1060},[1050,12827,12828],{"class":1052,"line":1473},[1050,12829,12830],{"class":1265},"        # Static files should serve quickly\n",[1050,12832,12833],{"class":1052,"line":1527},[1050,12834,12835],{"class":1265},"        # Note: These tests assume static files exist\n",[1050,12837,12838,12840,12843,12845,12847,12850,12852],{"class":1052,"line":1532},[1050,12839,1842],{"class":1056},[1050,12841,12842],{"class":1060}," css_response",[1050,12844,1090],{"class":1089},[1050,12846,2073],{"class":1278},[1050,12848,12849],{"class":1635}," ==",[1050,12851,2125],{"class":1306},[1050,12853,1847],{"class":1089},[1050,12855,12856,12858,12860,12862,12864,12866,12868,12871],{"class":1052,"line":1538},[1050,12857,1419],{"class":1272},[1050,12859,1090],{"class":1089},[1050,12861,3986],{"class":1331},[1050,12863,1197],{"class":1089},[1050,12865,12706],{"class":1331},[1050,12867,1101],{"class":1089},[1050,12869,12870],{"class":1306}," 0.1",[1050,12872,1436],{"class":1089},[1050,12874,12875,12877,12880,12882,12884,12886,12888],{"class":1052,"line":1552},[1050,12876,1842],{"class":1056},[1050,12878,12879],{"class":1060}," js_response",[1050,12881,1090],{"class":1089},[1050,12883,2073],{"class":1278},[1050,12885,12849],{"class":1635},[1050,12887,2125],{"class":1306},[1050,12889,1847],{"class":1089},[1050,12891,12892,12894,12896,12898,12900,12902,12904,12906],{"class":1052,"line":1570},[1050,12893,1419],{"class":1272},[1050,12895,1090],{"class":1089},[1050,12897,3986],{"class":1331},[1050,12899,1197],{"class":1089},[1050,12901,12751],{"class":1331},[1050,12903,1101],{"class":1089},[1050,12905,12870],{"class":1306},[1050,12907,1436],{"class":1089},[1050,12909,12910,12912,12915,12917,12919,12921,12923],{"class":1052,"line":1590},[1050,12911,1842],{"class":1056},[1050,12913,12914],{"class":1060}," img_response",[1050,12916,1090],{"class":1089},[1050,12918,2073],{"class":1278},[1050,12920,12849],{"class":1635},[1050,12922,2125],{"class":1306},[1050,12924,1847],{"class":1089},[1050,12926,12927,12929,12931,12933,12935,12937,12939,12942],{"class":1052,"line":1613},[1050,12928,1419],{"class":1272},[1050,12930,1090],{"class":1089},[1050,12932,3986],{"class":1331},[1050,12934,1197],{"class":1089},[1050,12936,12794],{"class":1331},[1050,12938,1101],{"class":1089},[1050,12940,12941],{"class":1306}," 0.2",[1050,12943,1436],{"class":1089},[1050,12945,12946],{"class":1052,"line":1647},[1050,12947,1224],{"class":1060},[1050,12949,12950,12952,12955,12957,12959],{"class":1052,"line":1684},[1050,12951,1230],{"class":1189},[1050,12953,12954],{"class":1233}," test_page_size_optimization",[1050,12956,1197],{"class":1089},[1050,12958,1240],{"class":1239},[1050,12960,1204],{"class":1089},[1050,12962,12963,12965,12968],{"class":1052,"line":1700},[1050,12964,1248],{"class":1210},[1050,12966,12967],{"class":1214},"Test page size and compression",[1050,12969,1218],{"class":1210},[1050,12971,12972],{"class":1052,"line":1715},[1050,12973,1259],{"class":1060},[1050,12975,12976],{"class":1052,"line":1720},[1050,12977,12978],{"class":1265},"        # Test main pages\n",[1050,12980,12981,12984,12986],{"class":1052,"line":1740},[1050,12982,12983],{"class":1060},"        pages ",[1050,12985,1318],{"class":1089},[1050,12987,5265],{"class":1089},[1050,12989,12990,12992,12994,12996,12998,13000,13002,13005,13007],{"class":1052,"line":1745},[1050,12991,5270],{"class":1089},[1050,12993,1364],{"class":1401},[1050,12995,3645],{"class":1350},[1050,12997,1364],{"class":1401},[1050,12999,1101],{"class":1089},[1050,13001,1915],{"class":1401},[1050,13003,13004],{"class":1350},"Homepage",[1050,13006,1364],{"class":1401},[1050,13008,2169],{"class":1089},[1050,13010,13011,13013,13015,13017,13019,13021,13023,13026,13028],{"class":1052,"line":1799},[1050,13012,5270],{"class":1089},[1050,13014,1364],{"class":1401},[1050,13016,4292],{"class":1350},[1050,13018,1364],{"class":1401},[1050,13020,1101],{"class":1089},[1050,13022,1915],{"class":1401},[1050,13024,13025],{"class":1350},"Blog List",[1050,13027,1364],{"class":1401},[1050,13029,2169],{"class":1089},[1050,13031,13032,13034,13036,13039,13041,13043,13045,13048,13050],{"class":1052,"line":1809},[1050,13033,5270],{"class":1089},[1050,13035,1364],{"class":1401},[1050,13037,13038],{"class":1350},"/about/",[1050,13040,1364],{"class":1401},[1050,13042,1101],{"class":1089},[1050,13044,1915],{"class":1401},[1050,13046,13047],{"class":1350},"About Page",[1050,13049,1364],{"class":1401},[1050,13051,2169],{"class":1089},[1050,13053,13054],{"class":1052,"line":1814},[1050,13055,5352],{"class":1089},[1050,13057,13058],{"class":1052,"line":1828},[1050,13059,1259],{"class":1060},[1050,13061,13062,13064,13066,13068,13071,13073,13076],{"class":1052,"line":1833},[1050,13063,1291],{"class":1056},[1050,13065,1760],{"class":1060},[1050,13067,1101],{"class":1089},[1050,13069,13070],{"class":1060}," name ",[1050,13072,1297],{"class":1056},[1050,13074,13075],{"class":1060}," pages",[1050,13077,1847],{"class":1089},[1050,13079,13080,13083,13085,13087,13089,13091,13093,13095,13097,13099],{"class":1052,"line":1839},[1050,13081,13082],{"class":1060},"            response ",[1050,13084,1318],{"class":1089},[1050,13086,2481],{"class":1272},[1050,13088,1090],{"class":1089},[1050,13090,10400],{"class":1278},[1050,13092,1090],{"class":1089},[1050,13094,1937],{"class":1331},[1050,13096,1197],{"class":1089},[1050,13098,1942],{"class":1331},[1050,13100,1436],{"class":1089},[1050,13102,13103],{"class":1052,"line":1850},[1050,13104,2034],{"class":1060},[1050,13106,13107,13109,13111,13113,13115,13117,13119],{"class":1052,"line":1867},[1050,13108,1906],{"class":1056},[1050,13110,2081],{"class":1060},[1050,13112,1090],{"class":1089},[1050,13114,2073],{"class":1278},[1050,13116,12849],{"class":1635},[1050,13118,2125],{"class":1306},[1050,13120,1847],{"class":1089},[1050,13122,13123,13126,13128,13130,13132,13134,13136,13138],{"class":1052,"line":1872},[1050,13124,13125],{"class":1060},"                content_length ",[1050,13127,1318],{"class":1089},[1050,13129,1670],{"class":1300},[1050,13131,1197],{"class":1089},[1050,13133,2161],{"class":1331},[1050,13135,1090],{"class":1089},[1050,13137,2166],{"class":1278},[1050,13139,1436],{"class":1089},[1050,13141,13142],{"class":1052,"line":1890},[1050,13143,9526],{"class":1060},[1050,13145,13146,13148,13150,13152,13154,13156,13158,13160,13163,13165,13167,13170,13172,13175],{"class":1052,"line":1895},[1050,13147,5624],{"class":1300},[1050,13149,1197],{"class":1089},[1050,13151,1347],{"class":1189},[1050,13153,2026],{"class":1350},[1050,13155,1355],{"class":1354},[1050,13157,1499],{"class":1331},[1050,13159,1361],{"class":1354},[1050,13161,13162],{"class":1350}," Size: ",[1050,13164,1355],{"class":1354},[1050,13166,2150],{"class":1331},[1050,13168,13169],{"class":1189},":,",[1050,13171,1361],{"class":1354},[1050,13173,13174],{"class":1350}," bytes\"",[1050,13176,1436],{"class":1089},[1050,13178,13179],{"class":1052,"line":1903},[1050,13180,9526],{"class":1060},[1050,13182,13183],{"class":1052,"line":1924},[1050,13184,13185],{"class":1265},"                # Pages should be reasonably sized\n",[1050,13187,13188,13191,13193,13195,13197,13199,13201,13204,13206],{"class":1052,"line":1947},[1050,13189,13190],{"class":1272},"                self",[1050,13192,1090],{"class":1089},[1050,13194,3986],{"class":1331},[1050,13196,1197],{"class":1089},[1050,13198,2150],{"class":1331},[1050,13200,1101],{"class":1089},[1050,13202,13203],{"class":1306}," 500000",[1050,13205,2619],{"class":1089},[1050,13207,13208],{"class":1265},"  # \u003C 500KB\n",[1050,13210,13211],{"class":1052,"line":1966},[1050,13212,9526],{"class":1060},[1050,13214,13215],{"class":1052,"line":1994},[1050,13216,13217],{"class":1265},"                # Check for compression headers (if enabled)\n",[1050,13219,13220,13222,13224,13227,13229,13232,13234,13236,13238,13240,13242,13245,13247,13249,13252],{"class":1052,"line":2002},[1050,13221,10882],{"class":1056},[1050,13223,1915],{"class":1401},[1050,13225,13226],{"class":1350},"gzip",[1050,13228,1364],{"class":1401},[1050,13230,13231],{"class":1635}," in",[1050,13233,2081],{"class":1060},[1050,13235,1090],{"class":1089},[1050,13237,1937],{"class":1331},[1050,13239,1197],{"class":1089},[1050,13241,1364],{"class":1401},[1050,13243,13244],{"class":1350},"Content-Encoding",[1050,13246,1364],{"class":1401},[1050,13248,1101],{"class":1089},[1050,13250,13251],{"class":1401}," ''",[1050,13253,1204],{"class":1089},[1050,13255,13256,13259,13261,13263,13265,13267,13269,13271,13274],{"class":1052,"line":2031},[1050,13257,13258],{"class":1300},"                    print",[1050,13260,1197],{"class":1089},[1050,13262,1347],{"class":1189},[1050,13264,2026],{"class":1350},[1050,13266,1355],{"class":1354},[1050,13268,1499],{"class":1331},[1050,13270,1361],{"class":1354},[1050,13272,13273],{"class":1350}," is gzipped\"",[1050,13275,1436],{"class":1089},[1050,13277,13278],{"class":1052,"line":2037},[1050,13279,1224],{"class":1060},[1050,13281,13282,13284,13287,13289,13291],{"class":1052,"line":2053},[1050,13283,1230],{"class":1189},[1050,13285,13286],{"class":1233}," test_template_rendering_performance",[1050,13288,1197],{"class":1089},[1050,13290,1240],{"class":1239},[1050,13292,1204],{"class":1089},[1050,13294,13295,13297,13300],{"class":1052,"line":2058},[1050,13296,1248],{"class":1210},[1050,13298,13299],{"class":1214},"Test template rendering performance",[1050,13301,1218],{"class":1210},[1050,13303,13304],{"class":1052,"line":2067},[1050,13305,1259],{"class":1060},[1050,13307,13308,13310,13312,13314,13317,13319,13322,13324],{"class":1052,"line":2090},[1050,13309,1453],{"class":1056},[1050,13311,1112],{"class":1060},[1050,13313,1090],{"class":1089},[1050,13315,13316],{"class":1060},"template ",[1050,13318,1057],{"class":1056},[1050,13320,13321],{"class":1060}," Template",[1050,13323,1101],{"class":1089},[1050,13325,13326],{"class":1060}," Context\n",[1050,13328,13329],{"class":1052,"line":2113},[1050,13330,1259],{"class":1060},[1050,13332,13333],{"class":1052,"line":2145},[1050,13334,13335],{"class":1265},"        # Test simple template\n",[1050,13337,13338,13341,13343,13345,13347],{"class":1052,"line":2172},[1050,13339,13340],{"class":1060},"        simple_template ",[1050,13342,1318],{"class":1089},[1050,13344,13321],{"class":1331},[1050,13346,1197],{"class":1089},[1050,13348,1218],{"class":1401},[1050,13350,13351],{"class":1052,"line":2187},[1050,13352,13353],{"class":1350},"        \u003Chtml>\n",[1050,13355,13356,13359,13362,13365,13368],{"class":1052,"line":2193},[1050,13357,13358],{"class":1350},"        \u003Chead>\u003Ctitle>",[1050,13360,13361],{"class":1354},"{{",[1050,13363,13364],{"class":1350}," title ",[1050,13366,13367],{"class":1354},"}}",[1050,13369,13370],{"class":1350},"\u003C/title>\u003C/head>\n",[1050,13372,13373],{"class":1052,"line":2198},[1050,13374,13375],{"class":1350},"        \u003Cbody>\n",[1050,13377,13378,13381,13383,13386,13388],{"class":1052,"line":2215},[1050,13379,13380],{"class":1350},"            \u003Ch1>",[1050,13382,13361],{"class":1354},[1050,13384,13385],{"class":1350}," heading ",[1050,13387,13367],{"class":1354},[1050,13389,13390],{"class":1350},"\u003C/h1>\n",[1050,13392,13393,13396,13398,13401,13403],{"class":1052,"line":2230},[1050,13394,13395],{"class":1350},"            \u003Cp>",[1050,13397,13361],{"class":1354},[1050,13399,13400],{"class":1350}," content ",[1050,13402,13367],{"class":1354},[1050,13404,13405],{"class":1350},"\u003C/p>\n",[1050,13407,13408],{"class":1052,"line":2237},[1050,13409,13410],{"class":1350},"        \u003C/body>\n",[1050,13412,13413],{"class":1052,"line":2253},[1050,13414,13415],{"class":1350},"        \u003C/html>\n",[1050,13417,13418,13420],{"class":1052,"line":2272},[1050,13419,1248],{"class":1401},[1050,13421,1436],{"class":1089},[1050,13423,13424],{"class":1052,"line":2288},[1050,13425,1259],{"class":1060},[1050,13427,13428,13431,13433,13436],{"class":1052,"line":2304},[1050,13429,13430],{"class":1060},"        simple_context ",[1050,13432,1318],{"class":1089},[1050,13434,13435],{"class":1331}," Context",[1050,13437,2789],{"class":1089},[1050,13439,13440,13442,13445,13447,13449,13451,13454,13456],{"class":1052,"line":2325},[1050,13441,3134],{"class":1401},[1050,13443,13444],{"class":1350},"title",[1050,13446,1364],{"class":1401},[1050,13448,2078],{"class":1089},[1050,13450,1915],{"class":1401},[1050,13452,13453],{"class":1350},"Test Page",[1050,13455,1364],{"class":1401},[1050,13457,1367],{"class":1089},[1050,13459,13460,13462,13465,13467,13469,13471,13474,13476],{"class":1052,"line":2330},[1050,13461,3134],{"class":1401},[1050,13463,13464],{"class":1350},"heading",[1050,13466,1364],{"class":1401},[1050,13468,2078],{"class":1089},[1050,13470,1915],{"class":1401},[1050,13472,13473],{"class":1350},"Welcome",[1050,13475,1364],{"class":1401},[1050,13477,1367],{"class":1089},[1050,13479,13480,13482,13484,13486,13488,13490,13493],{"class":1052,"line":2335},[1050,13481,3134],{"class":1401},[1050,13483,2166],{"class":1350},[1050,13485,1364],{"class":1401},[1050,13487,2078],{"class":1089},[1050,13489,1915],{"class":1401},[1050,13491,13492],{"class":1350},"This is test content.",[1050,13494,1407],{"class":1401},[1050,13496,13497],{"class":1052,"line":2374},[1050,13498,13499],{"class":1089},"        })\n",[1050,13501,13502],{"class":1052,"line":2408},[1050,13503,1259],{"class":1060},[1050,13505,13506,13508,13510,13512,13514,13516],{"class":1052,"line":2418},[1050,13507,1875],{"class":1060},[1050,13509,1318],{"class":1089},[1050,13511,1880],{"class":1060},[1050,13513,1090],{"class":1089},[1050,13515,1885],{"class":1331},[1050,13517,1825],{"class":1089},[1050,13519,13520,13522,13524,13526,13528,13530,13532],{"class":1052,"line":2423},[1050,13521,1291],{"class":1056},[1050,13523,2664],{"class":1060},[1050,13525,1297],{"class":1056},[1050,13527,1301],{"class":1300},[1050,13529,1197],{"class":1089},[1050,13531,7289],{"class":1306},[1050,13533,1204],{"class":1089},[1050,13535,13536,13539,13541,13544,13546,13549,13551,13554],{"class":1052,"line":2433},[1050,13537,13538],{"class":1060},"            rendered ",[1050,13540,1318],{"class":1089},[1050,13542,13543],{"class":1060}," simple_template",[1050,13545,1090],{"class":1089},[1050,13547,13548],{"class":1331},"render",[1050,13550,1197],{"class":1089},[1050,13552,13553],{"class":1331},"simple_context",[1050,13555,1436],{"class":1089},[1050,13557,13558,13561,13563,13565,13567,13569,13571,13573],{"class":1052,"line":2438},[1050,13559,13560],{"class":1060},"        simple_time ",[1050,13562,1318],{"class":1089},[1050,13564,1880],{"class":1060},[1050,13566,1090],{"class":1089},[1050,13568,1885],{"class":1331},[1050,13570,8758],{"class":1089},[1050,13572,3680],{"class":1635},[1050,13574,7721],{"class":1060},[1050,13576,13577],{"class":1052,"line":2450},[1050,13578,1259],{"class":1060},[1050,13580,13581],{"class":1052,"line":2461},[1050,13582,13583],{"class":1265},"        # Test complex template with loops\n",[1050,13585,13586,13589,13591,13593,13595],{"class":1052,"line":2470},[1050,13587,13588],{"class":1060},"        complex_template ",[1050,13590,1318],{"class":1089},[1050,13592,13321],{"class":1331},[1050,13594,1197],{"class":1089},[1050,13596,1218],{"class":1401},[1050,13598,13599],{"class":1052,"line":2490},[1050,13600,13353],{"class":1350},[1050,13602,13603,13605,13607,13609,13611],{"class":1052,"line":2496},[1050,13604,13358],{"class":1350},[1050,13606,13361],{"class":1354},[1050,13608,13364],{"class":1350},[1050,13610,13367],{"class":1354},[1050,13612,13370],{"class":1350},[1050,13614,13615],{"class":1052,"line":2533},[1050,13616,13375],{"class":1350},[1050,13618,13619,13621,13623,13625,13627],{"class":1052,"line":2555},[1050,13620,13380],{"class":1350},[1050,13622,13361],{"class":1354},[1050,13624,13385],{"class":1350},[1050,13626,13367],{"class":1354},[1050,13628,13390],{"class":1350},[1050,13630,13631],{"class":1052,"line":2560},[1050,13632,13633],{"class":1350},"            {% for item in items %}\n",[1050,13635,13636],{"class":1052,"line":2590},[1050,13637,13638],{"class":1350},"                \u003Cdiv class=\"item\">\n",[1050,13640,13641],{"class":1052,"line":2595},[1050,13642,13643],{"class":1350},"                    \u003Ch3>{{ item.title }}\u003C/h3>\n",[1050,13645,13646],{"class":1052,"line":2601},[1050,13647,13648],{"class":1350},"                    \u003Cp>{{ item.content|truncatewords:20 }}\u003C/p>\n",[1050,13650,13651],{"class":1052,"line":2629},[1050,13652,13653],{"class":1350},"                    \u003Csmall>By {{ item.author }} on {{ item.date|date:\"F j, Y\" }}\u003C/small>\n",[1050,13655,13656],{"class":1052,"line":2635},[1050,13657,13658],{"class":1350},"                \u003C/div>\n",[1050,13660,13661],{"class":1052,"line":2679},[1050,13662,13663],{"class":1350},"            {% endfor %}\n",[1050,13665,13666],{"class":1052,"line":2684},[1050,13667,13410],{"class":1350},[1050,13669,13670],{"class":1052,"line":2690},[1050,13671,13415],{"class":1350},[1050,13673,13674,13676],{"class":1052,"line":2711},[1050,13675,1248],{"class":1401},[1050,13677,1436],{"class":1089},[1050,13679,13680],{"class":1052,"line":2719},[1050,13681,1259],{"class":1060},[1050,13683,13684,13687,13689,13691],{"class":1052,"line":2750},[1050,13685,13686],{"class":1060},"        complex_context ",[1050,13688,1318],{"class":1089},[1050,13690,13435],{"class":1331},[1050,13692,2789],{"class":1089},[1050,13694,13695,13697,13699,13701,13703,13705,13708,13710],{"class":1052,"line":2766},[1050,13696,3134],{"class":1401},[1050,13698,13444],{"class":1350},[1050,13700,1364],{"class":1401},[1050,13702,2078],{"class":1089},[1050,13704,1915],{"class":1401},[1050,13706,13707],{"class":1350},"Complex Page",[1050,13709,1364],{"class":1401},[1050,13711,1367],{"class":1089},[1050,13713,13714,13716,13718,13720,13722,13724,13727,13729],{"class":1052,"line":2780},[1050,13715,3134],{"class":1401},[1050,13717,13464],{"class":1350},[1050,13719,1364],{"class":1401},[1050,13721,2078],{"class":1089},[1050,13723,1915],{"class":1401},[1050,13725,13726],{"class":1350},"Items List",[1050,13728,1364],{"class":1401},[1050,13730,1367],{"class":1089},[1050,13732,13733,13735,13737,13739,13741],{"class":1052,"line":2792},[1050,13734,3134],{"class":1401},[1050,13736,9802],{"class":1350},[1050,13738,1364],{"class":1401},[1050,13740,2078],{"class":1089},[1050,13742,5265],{"class":1089},[1050,13744,13745],{"class":1052,"line":2808},[1050,13746,13747],{"class":1089},"                {\n",[1050,13749,13750,13752,13754,13756,13758,13760,13763,13765,13767,13769,13771],{"class":1052,"line":2824},[1050,13751,6699],{"class":1401},[1050,13753,13444],{"class":1350},[1050,13755,1364],{"class":1401},[1050,13757,2078],{"class":1089},[1050,13759,2865],{"class":1189},[1050,13761,13762],{"class":1350},"'Item ",[1050,13764,1355],{"class":1354},[1050,13766,1358],{"class":1331},[1050,13768,1361],{"class":1354},[1050,13770,1364],{"class":1350},[1050,13772,1367],{"class":1089},[1050,13774,13775,13777,13779,13781,13783,13785,13788,13790,13792,13794,13796,13798,13800],{"class":1052,"line":2839},[1050,13776,6699],{"class":1401},[1050,13778,2166],{"class":1350},[1050,13780,1364],{"class":1401},[1050,13782,2078],{"class":1089},[1050,13784,2865],{"class":1189},[1050,13786,13787],{"class":1350},"'Content for item ",[1050,13789,1355],{"class":1354},[1050,13791,1358],{"class":1331},[1050,13793,1361],{"class":1354},[1050,13795,1632],{"class":1350},[1050,13797,1636],{"class":1635},[1050,13799,5326],{"class":1306},[1050,13801,1367],{"class":1089},[1050,13803,13804,13806,13808,13810,13812,13814,13817,13819,13821,13823,13825],{"class":1052,"line":2854},[1050,13805,6699],{"class":1401},[1050,13807,7641],{"class":1350},[1050,13809,1364],{"class":1401},[1050,13811,2078],{"class":1089},[1050,13813,2865],{"class":1189},[1050,13815,13816],{"class":1350},"'Author ",[1050,13818,1355],{"class":1354},[1050,13820,1358],{"class":1331},[1050,13822,1361],{"class":1354},[1050,13824,1364],{"class":1350},[1050,13826,1367],{"class":1089},[1050,13828,13829,13831,13834,13836,13838,13840,13842,13844],{"class":1052,"line":2880},[1050,13830,6699],{"class":1401},[1050,13832,13833],{"class":1350},"date",[1050,13835,1364],{"class":1401},[1050,13837,2078],{"class":1089},[1050,13839,1880],{"class":1331},[1050,13841,1090],{"class":1089},[1050,13843,1885],{"class":1331},[1050,13845,1825],{"class":1089},[1050,13847,13848],{"class":1052,"line":2886},[1050,13849,6736],{"class":1089},[1050,13851,13852,13854,13856,13858,13860,13862,13864],{"class":1052,"line":2891},[1050,13853,9663],{"class":1056},[1050,13855,1294],{"class":1331},[1050,13857,1297],{"class":1056},[1050,13859,1301],{"class":1300},[1050,13861,1197],{"class":1089},[1050,13863,3916],{"class":1306},[1050,13865,1436],{"class":1089},[1050,13867,13868],{"class":1052,"line":2911},[1050,13869,13870],{"class":1089},"            ]\n",[1050,13872,13873],{"class":1052,"line":2916},[1050,13874,13499],{"class":1089},[1050,13876,13877],{"class":1052,"line":2935},[1050,13878,1259],{"class":1060},[1050,13880,13881,13883,13885,13887,13889,13891],{"class":1052,"line":2945},[1050,13882,1875],{"class":1060},[1050,13884,1318],{"class":1089},[1050,13886,1880],{"class":1060},[1050,13888,1090],{"class":1089},[1050,13890,1885],{"class":1331},[1050,13892,1825],{"class":1089},[1050,13894,13895,13897,13899,13901,13903,13905,13907],{"class":1052,"line":2950},[1050,13896,1291],{"class":1056},[1050,13898,2664],{"class":1060},[1050,13900,1297],{"class":1056},[1050,13902,1301],{"class":1300},[1050,13904,1197],{"class":1089},[1050,13906,1565],{"class":1306},[1050,13908,1204],{"class":1089},[1050,13910,13911,13913,13915,13918,13920,13922,13924,13927],{"class":1052,"line":2962},[1050,13912,13538],{"class":1060},[1050,13914,1318],{"class":1089},[1050,13916,13917],{"class":1060}," complex_template",[1050,13919,1090],{"class":1089},[1050,13921,13548],{"class":1331},[1050,13923,1197],{"class":1089},[1050,13925,13926],{"class":1331},"complex_context",[1050,13928,1436],{"class":1089},[1050,13930,13931,13934,13936,13938,13940,13942,13944,13946],{"class":1052,"line":2988},[1050,13932,13933],{"class":1060},"        complex_time ",[1050,13935,1318],{"class":1089},[1050,13937,1880],{"class":1060},[1050,13939,1090],{"class":1089},[1050,13941,1885],{"class":1331},[1050,13943,8758],{"class":1089},[1050,13945,3680],{"class":1635},[1050,13947,7721],{"class":1060},[1050,13949,13950],{"class":1052,"line":2993},[1050,13951,1259],{"class":1060},[1050,13953,13954,13956,13958,13960,13963],{"class":1052,"line":2999},[1050,13955,4082],{"class":1300},[1050,13957,1197],{"class":1089},[1050,13959,1347],{"class":1189},[1050,13961,13962],{"class":1350},"\"Template Rendering Performance:\"",[1050,13964,1436],{"class":1089},[1050,13966,13967,13969,13971,13973,13976,13978,13981,13983,13985,13987],{"class":1052,"line":3034},[1050,13968,4082],{"class":1300},[1050,13970,1197],{"class":1089},[1050,13972,1347],{"class":1189},[1050,13974,13975],{"class":1350},"\"Simple Template (1000x): ",[1050,13977,1355],{"class":1354},[1050,13979,13980],{"class":1331},"simple_time",[1050,13982,4156],{"class":1189},[1050,13984,1361],{"class":1354},[1050,13986,4161],{"class":1350},[1050,13988,1436],{"class":1089},[1050,13990,13991,13993,13995,13997,14000,14002,14005,14007,14009,14011],{"class":1052,"line":3074},[1050,13992,4082],{"class":1300},[1050,13994,1197],{"class":1089},[1050,13996,1347],{"class":1189},[1050,13998,13999],{"class":1350},"\"Complex Template (100x): ",[1050,14001,1355],{"class":1354},[1050,14003,14004],{"class":1331},"complex_time",[1050,14006,4156],{"class":1189},[1050,14008,1361],{"class":1354},[1050,14010,4161],{"class":1350},[1050,14012,1436],{"class":1089},[1050,14014,14015],{"class":1052,"line":3110},[1050,14016,1259],{"class":1060},[1050,14018,14019],{"class":1052,"line":3115},[1050,14020,14021],{"class":1265},"        # Template rendering should be fast\n",[1050,14023,14024,14026,14028,14030,14032,14034,14036,14038],{"class":1052,"line":3121},[1050,14025,1273],{"class":1272},[1050,14027,1090],{"class":1089},[1050,14029,3986],{"class":1331},[1050,14031,1197],{"class":1089},[1050,14033,13980],{"class":1331},[1050,14035,1101],{"class":1089},[1050,14037,12375],{"class":1306},[1050,14039,1436],{"class":1089},[1050,14041,14042,14044,14046,14048,14050,14052,14054,14056],{"class":1052,"line":3131},[1050,14043,1273],{"class":1272},[1050,14045,1090],{"class":1089},[1050,14047,3986],{"class":1331},[1050,14049,1197],{"class":1089},[1050,14051,14004],{"class":1331},[1050,14053,1101],{"class":1089},[1050,14055,4003],{"class":1306},[1050,14057,1436],{"class":1089},[1030,14059,14061],{"id":14060},"performance-monitoring-and-alerting","Performance Monitoring and Alerting",[1035,14063,14065],{"id":14064},"continuous-performance-monitoring","Continuous Performance Monitoring",[1040,14067,14069],{"className":1042,"code":14068,"language":1044,"meta":1045,"style":1045},"class PerformanceMonitoringTests(TestCase):\n    \"\"\"Test performance monitoring and alerting\"\"\"\n    \n    def setUp(self):\n        self.performance_thresholds = {\n            'response_time_p95': 2.0,  # 95th percentile \u003C 2 seconds\n            'response_time_avg': 1.0,  # Average \u003C 1 second\n            'success_rate': 95.0,      # > 95% success rate\n            'requests_per_second': 50, # > 50 RPS\n            'memory_usage_mb': 500,    # \u003C 500MB memory usage\n        }\n    \n    def test_performance_regression_detection(self):\n        \"\"\"Test detection of performance regressions\"\"\"\n        \n        # Baseline performance measurement\n        baseline_results = self.measure_baseline_performance()\n        \n        # Simulate performance regression\n        regression_results = self.simulate_performance_regression()\n        \n        # Detect regressions\n        regressions = self.detect_regressions(baseline_results, regression_results)\n        \n        if regressions:\n            print(\"Performance Regressions Detected:\")\n            for metric, regression in regressions.items():\n                print(f\"  {metric}: {regression['change']:.1f}% worse\")\n        else:\n            print(\"No performance regressions detected\")\n    \n    def measure_baseline_performance(self):\n        \"\"\"Measure baseline performance metrics\"\"\"\n        \n        # Run standard load test\n        results = self.run_standard_load_test()\n        \n        return {\n            'avg_response_time': results['avg_response_time'],\n            'p95_response_time': results['p95_response_time'],\n            'success_rate': results['success_rate'],\n            'requests_per_second': results['requests_per_second']\n        }\n    \n    def simulate_performance_regression(self):\n        \"\"\"Simulate performance regression for testing\"\"\"\n        \n        # Add artificial delay to simulate regression\n        import time\n        \n        original_get = self.client.get\n        \n        def slow_get(*args, **kwargs):\n            time.sleep(0.1)  # Add 100ms delay\n            return original_get(*args, **kwargs)\n        \n        self.client.get = slow_get\n        \n        try:\n            results = self.run_standard_load_test()\n            return {\n                'avg_response_time': results['avg_response_time'],\n                'p95_response_time': results['p95_response_time'],\n                'success_rate': results['success_rate'],\n                'requests_per_second': results['requests_per_second']\n            }\n        finally:\n            # Restore original method\n            self.client.get = original_get\n    \n    def run_standard_load_test(self):\n        \"\"\"Run standard load test for monitoring\"\"\"\n        \n        # This would use the LoadTestingBase class methods\n        # Simplified version for this example\n        \n        results = []\n        for _ in range(20):\n            start_time = time.time()\n            response = self.client.get('/')\n            end_time = time.time()\n            \n            results.append({\n                'response_time': end_time - start_time,\n                'success': response.status_code == 200\n            })\n        \n        response_times = [r['response_time'] for r in results]\n        successful = [r for r in results if r['success']]\n        \n        return {\n            'avg_response_time': sum(response_times) / len(response_times),\n            'p95_response_time': sorted(response_times)[int(len(response_times) * 0.95)],\n            'success_rate': len(successful) / len(results) * 100,\n            'requests_per_second': len(results) / sum(response_times)\n        }\n    \n    def detect_regressions(self, baseline, current, threshold=10.0):\n        \"\"\"Detect performance regressions\"\"\"\n        \n        regressions = {}\n        \n        for metric in baseline:\n            if metric in current:\n                baseline_value = baseline[metric]\n                current_value = current[metric]\n                \n                # Calculate percentage change\n                if metric == 'success_rate':\n                    # For success rate, lower is worse\n                    change = (baseline_value - current_value) / baseline_value * 100\n                else:\n                    # For response times, higher is worse\n                    change = (current_value - baseline_value) / baseline_value * 100\n                \n                # Check if regression exceeds threshold\n                if change > threshold:\n                    regressions[metric] = {\n                        'baseline': baseline_value,\n                        'current': current_value,\n                        'change': change\n                    }\n        \n        return regressions\n    \n    def test_performance_alerting(self):\n        \"\"\"Test performance alerting system\"\"\"\n        \n        # Measure current performance\n        current_metrics = self.measure_baseline_performance()\n        \n        # Check against thresholds\n        alerts = []\n        \n        for metric, threshold in self.performance_thresholds.items():\n            if metric in current_metrics:\n                value = current_metrics[metric]\n                \n                if metric == 'success_rate':\n                    if value \u003C threshold:\n                        alerts.append(f\"{metric}: {value:.1f}% (threshold: {threshold}%)\")\n                else:\n                    if value > threshold:\n                        alerts.append(f\"{metric}: {value:.3f} (threshold: {threshold})\")\n        \n        if alerts:\n            print(\"Performance Alerts:\")\n            for alert in alerts:\n                print(f\"  ALERT: {alert}\")\n        else:\n            print(\"All performance metrics within thresholds\")\n        \n        # In a real system, you would send these alerts to monitoring systems\n        # like Datadog, New Relic, or custom alerting systems\n",[1047,14070,14071,14084,14093,14097,14109,14122,14140,14158,14175,14192,14210,14214,14218,14231,14240,14244,14249,14265,14269,14274,14290,14294,14299,14325,14329,14338,14353,14375,14420,14427,14442,14446,14459,14468,14472,14477,14492,14496,14502,14524,14546,14568,14590,14594,14598,14611,14620,14624,14629,14635,14639,14657,14661,14685,14703,14724,14728,14745,14749,14755,14769,14775,14797,14819,14841,14863,14867,14874,14879,14896,14900,14913,14922,14926,14931,14936,14940,14948,14964,14978,15004,15018,15022,15032,15050,15071,15076,15080,15110,15143,15147,15153,15181,15220,15255,15283,15287,15291,15324,15333,15337,15345,15349,15362,15374,15389,15404,15408,15413,15429,15434,15462,15469,15474,15500,15504,15509,15522,15537,15552,15567,15580,15584,15588,15595,15599,15612,15621,15625,15630,15645,15649,15654,15663,15667,15692,15705,15720,15724,15740,15754,15801,15807,15819,15863,15867,15876,15891,15904,15926,15932,15947,15951,15956],{"__ignoreMap":1045},[1050,14072,14073,14075,14078,14080,14082],{"class":1052,"line":1053},[1050,14074,1190],{"class":1189},[1050,14076,14077],{"class":1193}," PerformanceMonitoringTests",[1050,14079,1197],{"class":1089},[1050,14081,1201],{"class":1200},[1050,14083,1204],{"class":1089},[1050,14085,14086,14088,14091],{"class":1052,"line":1064},[1050,14087,1211],{"class":1210},[1050,14089,14090],{"class":1214},"Test performance monitoring and alerting",[1050,14092,1218],{"class":1210},[1050,14094,14095],{"class":1052,"line":1072},[1050,14096,1224],{"class":1060},[1050,14098,14099,14101,14103,14105,14107],{"class":1052,"line":1080},[1050,14100,1230],{"class":1189},[1050,14102,1234],{"class":1233},[1050,14104,1197],{"class":1089},[1050,14106,1240],{"class":1239},[1050,14108,1204],{"class":1089},[1050,14110,14111,14113,14115,14118,14120],{"class":1052,"line":1107},[1050,14112,1273],{"class":1272},[1050,14114,1090],{"class":1089},[1050,14116,14117],{"class":1278},"performance_thresholds",[1050,14119,1282],{"class":1089},[1050,14121,2064],{"class":1089},[1050,14123,14124,14126,14129,14131,14133,14135,14137],{"class":1052,"line":1130},[1050,14125,3134],{"class":1401},[1050,14127,14128],{"class":1350},"response_time_p95",[1050,14130,1364],{"class":1401},[1050,14132,2078],{"class":1089},[1050,14134,4003],{"class":1306},[1050,14136,1101],{"class":1089},[1050,14138,14139],{"class":1265},"  # 95th percentile \u003C 2 seconds\n",[1050,14141,14142,14144,14147,14149,14151,14153,14155],{"class":1052,"line":1152},[1050,14143,3134],{"class":1401},[1050,14145,14146],{"class":1350},"response_time_avg",[1050,14148,1364],{"class":1401},[1050,14150,2078],{"class":1089},[1050,14152,12375],{"class":1306},[1050,14154,1101],{"class":1089},[1050,14156,14157],{"class":1265},"  # Average \u003C 1 second\n",[1050,14159,14160,14162,14164,14166,14168,14170,14172],{"class":1052,"line":1179},[1050,14161,3134],{"class":1401},[1050,14163,3197],{"class":1350},[1050,14165,1364],{"class":1401},[1050,14167,2078],{"class":1089},[1050,14169,3974],{"class":1306},[1050,14171,1101],{"class":1089},[1050,14173,14174],{"class":1265},"      # > 95% success rate\n",[1050,14176,14177,14179,14181,14183,14185,14187,14189],{"class":1052,"line":1186},[1050,14178,3134],{"class":1401},[1050,14180,3421],{"class":1350},[1050,14182,1364],{"class":1401},[1050,14184,2078],{"class":1089},[1050,14186,1639],{"class":1306},[1050,14188,1101],{"class":1089},[1050,14190,14191],{"class":1265}," # > 50 RPS\n",[1050,14193,14194,14196,14199,14201,14203,14205,14207],{"class":1052,"line":1207},[1050,14195,3134],{"class":1401},[1050,14197,14198],{"class":1350},"memory_usage_mb",[1050,14200,1364],{"class":1401},[1050,14202,2078],{"class":1089},[1050,14204,2248],{"class":1306},[1050,14206,1101],{"class":1089},[1050,14208,14209],{"class":1265},"    # \u003C 500MB memory usage\n",[1050,14211,14212],{"class":1052,"line":1221},[1050,14213,3546],{"class":1089},[1050,14215,14216],{"class":1052,"line":1227},[1050,14217,1224],{"class":1060},[1050,14219,14220,14222,14225,14227,14229],{"class":1052,"line":1245},[1050,14221,1230],{"class":1189},[1050,14223,14224],{"class":1233}," test_performance_regression_detection",[1050,14226,1197],{"class":1089},[1050,14228,1240],{"class":1239},[1050,14230,1204],{"class":1089},[1050,14232,14233,14235,14238],{"class":1052,"line":1256},[1050,14234,1248],{"class":1210},[1050,14236,14237],{"class":1214},"Test detection of performance regressions",[1050,14239,1218],{"class":1210},[1050,14241,14242],{"class":1052,"line":1262},[1050,14243,1259],{"class":1060},[1050,14245,14246],{"class":1052,"line":1269},[1050,14247,14248],{"class":1265},"        # Baseline performance measurement\n",[1050,14250,14251,14254,14256,14258,14260,14263],{"class":1052,"line":1288},[1050,14252,14253],{"class":1060},"        baseline_results ",[1050,14255,1318],{"class":1089},[1050,14257,2481],{"class":1272},[1050,14259,1090],{"class":1089},[1050,14261,14262],{"class":1331},"measure_baseline_performance",[1050,14264,1825],{"class":1089},[1050,14266,14267],{"class":1052,"line":1312},[1050,14268,1259],{"class":1060},[1050,14270,14271],{"class":1052,"line":1338},[1050,14272,14273],{"class":1265},"        # Simulate performance regression\n",[1050,14275,14276,14279,14281,14283,14285,14288],{"class":1052,"line":1370},[1050,14277,14278],{"class":1060},"        regression_results ",[1050,14280,1318],{"class":1089},[1050,14282,2481],{"class":1272},[1050,14284,1090],{"class":1089},[1050,14286,14287],{"class":1331},"simulate_performance_regression",[1050,14289,1825],{"class":1089},[1050,14291,14292],{"class":1052,"line":1393},[1050,14293,1259],{"class":1060},[1050,14295,14296],{"class":1052,"line":1410},[1050,14297,14298],{"class":1265},"        # Detect regressions\n",[1050,14300,14301,14304,14306,14308,14310,14313,14315,14318,14320,14323],{"class":1052,"line":1416},[1050,14302,14303],{"class":1060},"        regressions ",[1050,14305,1318],{"class":1089},[1050,14307,2481],{"class":1272},[1050,14309,1090],{"class":1089},[1050,14311,14312],{"class":1331},"detect_regressions",[1050,14314,1197],{"class":1089},[1050,14316,14317],{"class":1331},"baseline_results",[1050,14319,1101],{"class":1089},[1050,14321,14322],{"class":1331}," regression_results",[1050,14324,1436],{"class":1089},[1050,14326,14327],{"class":1052,"line":1439},[1050,14328,1259],{"class":1060},[1050,14330,14331,14333,14336],{"class":1052,"line":1444},[1050,14332,1842],{"class":1056},[1050,14334,14335],{"class":1060}," regressions",[1050,14337,1847],{"class":1089},[1050,14339,14340,14342,14344,14346,14349,14351],{"class":1052,"line":1450},[1050,14341,5392],{"class":1300},[1050,14343,1197],{"class":1089},[1050,14345,2026],{"class":1401},[1050,14347,14348],{"class":1350},"Performance Regressions Detected:",[1050,14350,2026],{"class":1401},[1050,14352,1436],{"class":1089},[1050,14354,14355,14357,14360,14362,14365,14367,14369,14371,14373],{"class":1052,"line":1473},[1050,14356,2693],{"class":1056},[1050,14358,14359],{"class":1060}," metric",[1050,14361,1101],{"class":1089},[1050,14363,14364],{"class":1060}," regression ",[1050,14366,1297],{"class":1056},[1050,14368,14335],{"class":1060},[1050,14370,1090],{"class":1089},[1050,14372,9802],{"class":1331},[1050,14374,2447],{"class":1089},[1050,14376,14377,14379,14381,14383,14386,14388,14391,14393,14395,14397,14400,14402,14404,14407,14409,14411,14413,14415,14418],{"class":1052,"line":1527},[1050,14378,5624],{"class":1300},[1050,14380,1197],{"class":1089},[1050,14382,1347],{"class":1189},[1050,14384,14385],{"class":1350},"\"  ",[1050,14387,1355],{"class":1354},[1050,14389,14390],{"class":1331},"metric",[1050,14392,1361],{"class":1354},[1050,14394,9823],{"class":1350},[1050,14396,1355],{"class":1354},[1050,14398,14399],{"class":1331},"regression",[1050,14401,1661],{"class":1089},[1050,14403,1364],{"class":1401},[1050,14405,14406],{"class":1350},"change",[1050,14408,1364],{"class":1401},[1050,14410,3020],{"class":1089},[1050,14412,4120],{"class":1189},[1050,14414,1361],{"class":1354},[1050,14416,14417],{"class":1350},"% worse\"",[1050,14419,1436],{"class":1089},[1050,14421,14422,14425],{"class":1052,"line":1532},[1050,14423,14424],{"class":1056},"        else",[1050,14426,1847],{"class":1089},[1050,14428,14429,14431,14433,14435,14438,14440],{"class":1052,"line":1538},[1050,14430,5392],{"class":1300},[1050,14432,1197],{"class":1089},[1050,14434,2026],{"class":1401},[1050,14436,14437],{"class":1350},"No performance regressions detected",[1050,14439,2026],{"class":1401},[1050,14441,1436],{"class":1089},[1050,14443,14444],{"class":1052,"line":1552},[1050,14445,1224],{"class":1060},[1050,14447,14448,14450,14453,14455,14457],{"class":1052,"line":1570},[1050,14449,1230],{"class":1189},[1050,14451,14452],{"class":1233}," measure_baseline_performance",[1050,14454,1197],{"class":1089},[1050,14456,1240],{"class":1239},[1050,14458,1204],{"class":1089},[1050,14460,14461,14463,14466],{"class":1052,"line":1590},[1050,14462,1248],{"class":1210},[1050,14464,14465],{"class":1214},"Measure baseline performance metrics",[1050,14467,1218],{"class":1210},[1050,14469,14470],{"class":1052,"line":1613},[1050,14471,1259],{"class":1060},[1050,14473,14474],{"class":1052,"line":1647},[1050,14475,14476],{"class":1265},"        # Run standard load test\n",[1050,14478,14479,14481,14483,14485,14487,14490],{"class":1052,"line":1684},[1050,14480,2426],{"class":1060},[1050,14482,1318],{"class":1089},[1050,14484,2481],{"class":1272},[1050,14486,1090],{"class":1089},[1050,14488,14489],{"class":1331},"run_standard_load_test",[1050,14491,1825],{"class":1089},[1050,14493,14494],{"class":1052,"line":1700},[1050,14495,1259],{"class":1060},[1050,14497,14498,14500],{"class":1052,"line":1715},[1050,14499,2894],{"class":1056},[1050,14501,2064],{"class":1089},[1050,14503,14504,14506,14508,14510,14512,14514,14516,14518,14520,14522],{"class":1052,"line":1720},[1050,14505,3134],{"class":1401},[1050,14507,3246],{"class":1350},[1050,14509,1364],{"class":1401},[1050,14511,2078],{"class":1089},[1050,14513,2930],{"class":1060},[1050,14515,1661],{"class":1089},[1050,14517,1364],{"class":1401},[1050,14519,3246],{"class":1350},[1050,14521,1364],{"class":1401},[1050,14523,8699],{"class":1089},[1050,14525,14526,14528,14530,14532,14534,14536,14538,14540,14542,14544],{"class":1052,"line":1740},[1050,14527,3134],{"class":1401},[1050,14529,3351],{"class":1350},[1050,14531,1364],{"class":1401},[1050,14533,2078],{"class":1089},[1050,14535,2930],{"class":1060},[1050,14537,1661],{"class":1089},[1050,14539,1364],{"class":1401},[1050,14541,3351],{"class":1350},[1050,14543,1364],{"class":1401},[1050,14545,8699],{"class":1089},[1050,14547,14548,14550,14552,14554,14556,14558,14560,14562,14564,14566],{"class":1052,"line":1745},[1050,14549,3134],{"class":1401},[1050,14551,3197],{"class":1350},[1050,14553,1364],{"class":1401},[1050,14555,2078],{"class":1089},[1050,14557,2930],{"class":1060},[1050,14559,1661],{"class":1089},[1050,14561,1364],{"class":1401},[1050,14563,3197],{"class":1350},[1050,14565,1364],{"class":1401},[1050,14567,8699],{"class":1089},[1050,14569,14570,14572,14574,14576,14578,14580,14582,14584,14586,14588],{"class":1052,"line":1799},[1050,14571,3134],{"class":1401},[1050,14573,3421],{"class":1350},[1050,14575,1364],{"class":1401},[1050,14577,2078],{"class":1089},[1050,14579,2930],{"class":1060},[1050,14581,1661],{"class":1089},[1050,14583,1364],{"class":1401},[1050,14585,3421],{"class":1350},[1050,14587,1364],{"class":1401},[1050,14589,2552],{"class":1089},[1050,14591,14592],{"class":1052,"line":1809},[1050,14593,3546],{"class":1089},[1050,14595,14596],{"class":1052,"line":1814},[1050,14597,1224],{"class":1060},[1050,14599,14600,14602,14605,14607,14609],{"class":1052,"line":1828},[1050,14601,1230],{"class":1189},[1050,14603,14604],{"class":1233}," simulate_performance_regression",[1050,14606,1197],{"class":1089},[1050,14608,1240],{"class":1239},[1050,14610,1204],{"class":1089},[1050,14612,14613,14615,14618],{"class":1052,"line":1833},[1050,14614,1248],{"class":1210},[1050,14616,14617],{"class":1214},"Simulate performance regression for testing",[1050,14619,1218],{"class":1210},[1050,14621,14622],{"class":1052,"line":1839},[1050,14623,1259],{"class":1060},[1050,14625,14626],{"class":1052,"line":1850},[1050,14627,14628],{"class":1265},"        # Add artificial delay to simulate regression\n",[1050,14630,14631,14633],{"class":1052,"line":1867},[1050,14632,6180],{"class":1056},[1050,14634,1061],{"class":1060},[1050,14636,14637],{"class":1052,"line":1872},[1050,14638,1259],{"class":1060},[1050,14640,14641,14644,14646,14648,14650,14652,14654],{"class":1052,"line":1890},[1050,14642,14643],{"class":1060},"        original_get ",[1050,14645,1318],{"class":1089},[1050,14647,2481],{"class":1272},[1050,14649,1090],{"class":1089},[1050,14651,10400],{"class":1278},[1050,14653,1090],{"class":1089},[1050,14655,14656],{"class":1278},"get\n",[1050,14658,14659],{"class":1052,"line":1895},[1050,14660,1259],{"class":1060},[1050,14662,14663,14665,14668,14670,14672,14675,14677,14680,14683],{"class":1052,"line":1903},[1050,14664,2441],{"class":1189},[1050,14666,14667],{"class":1233}," slow_get",[1050,14669,1197],{"class":1089},[1050,14671,8318],{"class":1635},[1050,14673,14674],{"class":1759},"args",[1050,14676,1101],{"class":1089},[1050,14678,14679],{"class":1635}," **",[1050,14681,14682],{"class":1759},"kwargs",[1050,14684,1204],{"class":1089},[1050,14686,14687,14689,14691,14693,14695,14698,14700],{"class":1052,"line":1924},[1050,14688,5669],{"class":1060},[1050,14690,1090],{"class":1089},[1050,14692,5674],{"class":1331},[1050,14694,1197],{"class":1089},[1050,14696,14697],{"class":1306},"0.1",[1050,14699,2619],{"class":1089},[1050,14701,14702],{"class":1265},"  # Add 100ms delay\n",[1050,14704,14705,14707,14710,14712,14714,14716,14718,14720,14722],{"class":1052,"line":1947},[1050,14706,2061],{"class":1056},[1050,14708,14709],{"class":1331}," original_get",[1050,14711,1197],{"class":1089},[1050,14713,8318],{"class":1635},[1050,14715,14674],{"class":1331},[1050,14717,1101],{"class":1089},[1050,14719,14679],{"class":1635},[1050,14721,14682],{"class":1331},[1050,14723,1436],{"class":1089},[1050,14725,14726],{"class":1052,"line":1966},[1050,14727,1259],{"class":1060},[1050,14729,14730,14732,14734,14736,14738,14740,14742],{"class":1052,"line":1994},[1050,14731,1273],{"class":1272},[1050,14733,1090],{"class":1089},[1050,14735,10400],{"class":1278},[1050,14737,1090],{"class":1089},[1050,14739,1937],{"class":1278},[1050,14741,1282],{"class":1089},[1050,14743,14744],{"class":1060}," slow_get\n",[1050,14746,14747],{"class":1052,"line":2002},[1050,14748,1259],{"class":1060},[1050,14750,14751,14753],{"class":1052,"line":2031},[1050,14752,1898],{"class":1056},[1050,14754,1847],{"class":1089},[1050,14756,14757,14759,14761,14763,14765,14767],{"class":1052,"line":2037},[1050,14758,4659],{"class":1060},[1050,14760,1318],{"class":1089},[1050,14762,2481],{"class":1272},[1050,14764,1090],{"class":1089},[1050,14766,14489],{"class":1331},[1050,14768,1825],{"class":1089},[1050,14770,14771,14773],{"class":1052,"line":2053},[1050,14772,2061],{"class":1056},[1050,14774,2064],{"class":1089},[1050,14776,14777,14779,14781,14783,14785,14787,14789,14791,14793,14795],{"class":1052,"line":2058},[1050,14778,2070],{"class":1401},[1050,14780,3246],{"class":1350},[1050,14782,1364],{"class":1401},[1050,14784,2078],{"class":1089},[1050,14786,2930],{"class":1060},[1050,14788,1661],{"class":1089},[1050,14790,1364],{"class":1401},[1050,14792,3246],{"class":1350},[1050,14794,1364],{"class":1401},[1050,14796,8699],{"class":1089},[1050,14798,14799,14801,14803,14805,14807,14809,14811,14813,14815,14817],{"class":1052,"line":2067},[1050,14800,2070],{"class":1401},[1050,14802,3351],{"class":1350},[1050,14804,1364],{"class":1401},[1050,14806,2078],{"class":1089},[1050,14808,2930],{"class":1060},[1050,14810,1661],{"class":1089},[1050,14812,1364],{"class":1401},[1050,14814,3351],{"class":1350},[1050,14816,1364],{"class":1401},[1050,14818,8699],{"class":1089},[1050,14820,14821,14823,14825,14827,14829,14831,14833,14835,14837,14839],{"class":1052,"line":2090},[1050,14822,2070],{"class":1401},[1050,14824,3197],{"class":1350},[1050,14826,1364],{"class":1401},[1050,14828,2078],{"class":1089},[1050,14830,2930],{"class":1060},[1050,14832,1661],{"class":1089},[1050,14834,1364],{"class":1401},[1050,14836,3197],{"class":1350},[1050,14838,1364],{"class":1401},[1050,14840,8699],{"class":1089},[1050,14842,14843,14845,14847,14849,14851,14853,14855,14857,14859,14861],{"class":1052,"line":2113},[1050,14844,2070],{"class":1401},[1050,14846,3421],{"class":1350},[1050,14848,1364],{"class":1401},[1050,14850,2078],{"class":1089},[1050,14852,2930],{"class":1060},[1050,14854,1661],{"class":1089},[1050,14856,1364],{"class":1401},[1050,14858,3421],{"class":1350},[1050,14860,1364],{"class":1401},[1050,14862,2552],{"class":1089},[1050,14864,14865],{"class":1052,"line":2145},[1050,14866,2190],{"class":1089},[1050,14868,14869,14872],{"class":1052,"line":2172},[1050,14870,14871],{"class":1056},"        finally",[1050,14873,1847],{"class":1089},[1050,14875,14876],{"class":1052,"line":2187},[1050,14877,14878],{"class":1265},"            # Restore original method\n",[1050,14880,14881,14883,14885,14887,14889,14891,14893],{"class":1052,"line":2193},[1050,14882,1419],{"class":1272},[1050,14884,1090],{"class":1089},[1050,14886,10400],{"class":1278},[1050,14888,1090],{"class":1089},[1050,14890,1937],{"class":1278},[1050,14892,1282],{"class":1089},[1050,14894,14895],{"class":1060}," original_get\n",[1050,14897,14898],{"class":1052,"line":2198},[1050,14899,1224],{"class":1060},[1050,14901,14902,14904,14907,14909,14911],{"class":1052,"line":2215},[1050,14903,1230],{"class":1189},[1050,14905,14906],{"class":1233}," run_standard_load_test",[1050,14908,1197],{"class":1089},[1050,14910,1240],{"class":1239},[1050,14912,1204],{"class":1089},[1050,14914,14915,14917,14920],{"class":1052,"line":2230},[1050,14916,1248],{"class":1210},[1050,14918,14919],{"class":1214},"Run standard load test for monitoring",[1050,14921,1218],{"class":1210},[1050,14923,14924],{"class":1052,"line":2237},[1050,14925,1259],{"class":1060},[1050,14927,14928],{"class":1052,"line":2253},[1050,14929,14930],{"class":1265},"        # This would use the LoadTestingBase class methods\n",[1050,14932,14933],{"class":1052,"line":2272},[1050,14934,14935],{"class":1265},"        # Simplified version for this example\n",[1050,14937,14938],{"class":1052,"line":2288},[1050,14939,1259],{"class":1060},[1050,14941,14942,14944,14946],{"class":1052,"line":2304},[1050,14943,2426],{"class":1060},[1050,14945,1318],{"class":1089},[1050,14947,1285],{"class":1089},[1050,14949,14950,14952,14954,14956,14958,14960,14962],{"class":1052,"line":2325},[1050,14951,1291],{"class":1056},[1050,14953,2664],{"class":1060},[1050,14955,1297],{"class":1056},[1050,14957,1301],{"class":1300},[1050,14959,1197],{"class":1089},[1050,14961,4692],{"class":1306},[1050,14963,1204],{"class":1089},[1050,14965,14966,14968,14970,14972,14974,14976],{"class":1052,"line":2330},[1050,14967,7560],{"class":1060},[1050,14969,1318],{"class":1089},[1050,14971,1880],{"class":1060},[1050,14973,1090],{"class":1089},[1050,14975,1885],{"class":1331},[1050,14977,1825],{"class":1089},[1050,14979,14980,14982,14984,14986,14988,14990,14992,14994,14996,14998,15000,15002],{"class":1052,"line":2335},[1050,14981,13082],{"class":1060},[1050,14983,1318],{"class":1089},[1050,14985,2481],{"class":1272},[1050,14987,1090],{"class":1089},[1050,14989,10400],{"class":1278},[1050,14991,1090],{"class":1089},[1050,14993,1937],{"class":1331},[1050,14995,1197],{"class":1089},[1050,14997,1364],{"class":1401},[1050,14999,3645],{"class":1350},[1050,15001,1364],{"class":1401},[1050,15003,1436],{"class":1089},[1050,15005,15006,15008,15010,15012,15014,15016],{"class":1052,"line":2374},[1050,15007,2040],{"class":1060},[1050,15009,1318],{"class":1089},[1050,15011,1880],{"class":1060},[1050,15013,1090],{"class":1089},[1050,15015,1885],{"class":1331},[1050,15017,1825],{"class":1089},[1050,15019,15020],{"class":1052,"line":2408},[1050,15021,2034],{"class":1060},[1050,15023,15024,15026,15028,15030],{"class":1052,"line":2418},[1050,15025,5483],{"class":1060},[1050,15027,1090],{"class":1089},[1050,15029,1428],{"class":1331},[1050,15031,2789],{"class":1089},[1050,15033,15034,15036,15038,15040,15042,15044,15046,15048],{"class":1052,"line":2423},[1050,15035,2070],{"class":1401},[1050,15037,2095],{"class":1350},[1050,15039,1364],{"class":1401},[1050,15041,2078],{"class":1089},[1050,15043,2102],{"class":1331},[1050,15045,2105],{"class":1635},[1050,15047,2108],{"class":1331},[1050,15049,1367],{"class":1089},[1050,15051,15052,15054,15056,15058,15060,15062,15064,15066,15068],{"class":1052,"line":2433},[1050,15053,2070],{"class":1401},[1050,15055,2118],{"class":1350},[1050,15057,1364],{"class":1401},[1050,15059,2078],{"class":1089},[1050,15061,2081],{"class":1331},[1050,15063,1090],{"class":1089},[1050,15065,2073],{"class":1278},[1050,15067,12849],{"class":1635},[1050,15069,15070],{"class":1306}," 200\n",[1050,15072,15073],{"class":1052,"line":2438},[1050,15074,15075],{"class":1089},"            })\n",[1050,15077,15078],{"class":1052,"line":2450},[1050,15079,1259],{"class":1060},[1050,15081,15082,15084,15086,15088,15090,15092,15094,15096,15098,15100,15102,15104,15106,15108],{"class":1052,"line":2461},[1050,15083,3002],{"class":1060},[1050,15085,1318],{"class":1089},[1050,15087,2643],{"class":1089},[1050,15089,3009],{"class":1060},[1050,15091,1661],{"class":1089},[1050,15093,1364],{"class":1401},[1050,15095,2095],{"class":1350},[1050,15097,1364],{"class":1401},[1050,15099,3020],{"class":1089},[1050,15101,2661],{"class":1056},[1050,15103,3025],{"class":1060},[1050,15105,1297],{"class":1056},[1050,15107,2930],{"class":1060},[1050,15109,2552],{"class":1089},[1050,15111,15112,15115,15117,15119,15121,15123,15125,15127,15129,15131,15133,15135,15137,15139,15141],{"class":1052,"line":2470},[1050,15113,15114],{"class":1060},"        successful ",[1050,15116,1318],{"class":1089},[1050,15118,2643],{"class":1089},[1050,15120,3044],{"class":1060},[1050,15122,3047],{"class":1056},[1050,15124,3025],{"class":1060},[1050,15126,1297],{"class":1056},[1050,15128,3054],{"class":1060},[1050,15130,3057],{"class":1056},[1050,15132,3060],{"class":1060},[1050,15134,1661],{"class":1089},[1050,15136,1364],{"class":1401},[1050,15138,2118],{"class":1350},[1050,15140,1364],{"class":1401},[1050,15142,3071],{"class":1089},[1050,15144,15145],{"class":1052,"line":2490},[1050,15146,1259],{"class":1060},[1050,15148,15149,15151],{"class":1052,"line":2496},[1050,15150,2894],{"class":1056},[1050,15152,2064],{"class":1089},[1050,15154,15155,15157,15159,15161,15163,15165,15167,15169,15171,15173,15175,15177,15179],{"class":1052,"line":2533},[1050,15156,3134],{"class":1401},[1050,15158,3246],{"class":1350},[1050,15160,1364],{"class":1401},[1050,15162,2078],{"class":1089},[1050,15164,3438],{"class":1300},[1050,15166,1197],{"class":1089},[1050,15168,3263],{"class":1331},[1050,15170,2619],{"class":1089},[1050,15172,3212],{"class":1635},[1050,15174,1670],{"class":1300},[1050,15176,1197],{"class":1089},[1050,15178,3263],{"class":1331},[1050,15180,2169],{"class":1089},[1050,15182,15183,15185,15187,15189,15191,15193,15195,15197,15200,15203,15205,15207,15209,15211,15213,15215,15218],{"class":1052,"line":2555},[1050,15184,3134],{"class":1401},[1050,15186,3351],{"class":1350},[1050,15188,1364],{"class":1401},[1050,15190,2078],{"class":1089},[1050,15192,3607],{"class":1300},[1050,15194,1197],{"class":1089},[1050,15196,3263],{"class":1331},[1050,15198,15199],{"class":1089},")[",[1050,15201,15202],{"class":2008},"int",[1050,15204,1197],{"class":1089},[1050,15206,3630],{"class":1300},[1050,15208,1197],{"class":1089},[1050,15210,3263],{"class":1331},[1050,15212,2619],{"class":1089},[1050,15214,1636],{"class":1635},[1050,15216,15217],{"class":1306}," 0.95",[1050,15219,1681],{"class":1089},[1050,15221,15222,15224,15226,15228,15230,15232,15234,15237,15239,15241,15243,15245,15247,15249,15251,15253],{"class":1052,"line":2560},[1050,15223,3134],{"class":1401},[1050,15225,3197],{"class":1350},[1050,15227,1364],{"class":1401},[1050,15229,2078],{"class":1089},[1050,15231,1670],{"class":1300},[1050,15233,1197],{"class":1089},[1050,15235,15236],{"class":1331},"successful",[1050,15238,2619],{"class":1089},[1050,15240,3212],{"class":1635},[1050,15242,1670],{"class":1300},[1050,15244,1197],{"class":1089},[1050,15246,2906],{"class":1331},[1050,15248,2619],{"class":1089},[1050,15250,1636],{"class":1635},[1050,15252,3225],{"class":1306},[1050,15254,1367],{"class":1089},[1050,15256,15257,15259,15261,15263,15265,15267,15269,15271,15273,15275,15277,15279,15281],{"class":1052,"line":2590},[1050,15258,3134],{"class":1401},[1050,15260,3421],{"class":1350},[1050,15262,1364],{"class":1401},[1050,15264,2078],{"class":1089},[1050,15266,1670],{"class":1300},[1050,15268,1197],{"class":1089},[1050,15270,2906],{"class":1331},[1050,15272,2619],{"class":1089},[1050,15274,3212],{"class":1635},[1050,15276,3438],{"class":1300},[1050,15278,1197],{"class":1089},[1050,15280,3263],{"class":1331},[1050,15282,1436],{"class":1089},[1050,15284,15285],{"class":1052,"line":2595},[1050,15286,3546],{"class":1089},[1050,15288,15289],{"class":1052,"line":2601},[1050,15290,1224],{"class":1060},[1050,15292,15293,15295,15298,15300,15302,15304,15307,15309,15312,15314,15317,15319,15322],{"class":1052,"line":2629},[1050,15294,1230],{"class":1189},[1050,15296,15297],{"class":1233}," detect_regressions",[1050,15299,1197],{"class":1089},[1050,15301,1240],{"class":1239},[1050,15303,1101],{"class":1089},[1050,15305,15306],{"class":1759}," baseline",[1050,15308,1101],{"class":1089},[1050,15310,15311],{"class":1759}," current",[1050,15313,1101],{"class":1089},[1050,15315,15316],{"class":1759}," threshold",[1050,15318,1318],{"class":1635},[1050,15320,15321],{"class":1306},"10.0",[1050,15323,1204],{"class":1089},[1050,15325,15326,15328,15331],{"class":1052,"line":2635},[1050,15327,1248],{"class":1210},[1050,15329,15330],{"class":1214},"Detect performance regressions",[1050,15332,1218],{"class":1210},[1050,15334,15335],{"class":1052,"line":2679},[1050,15336,1259],{"class":1060},[1050,15338,15339,15341,15343],{"class":1052,"line":2684},[1050,15340,14303],{"class":1060},[1050,15342,1318],{"class":1089},[1050,15344,3729],{"class":1089},[1050,15346,15347],{"class":1052,"line":2690},[1050,15348,1259],{"class":1060},[1050,15350,15351,15353,15356,15358,15360],{"class":1052,"line":2711},[1050,15352,1291],{"class":1056},[1050,15354,15355],{"class":1060}," metric ",[1050,15357,1297],{"class":1056},[1050,15359,15306],{"class":1060},[1050,15361,1847],{"class":1089},[1050,15363,15364,15366,15368,15370,15372],{"class":1052,"line":2719},[1050,15365,1906],{"class":1056},[1050,15367,15355],{"class":1060},[1050,15369,1297],{"class":1635},[1050,15371,15311],{"class":1060},[1050,15373,1847],{"class":1089},[1050,15375,15376,15379,15381,15383,15385,15387],{"class":1052,"line":2750},[1050,15377,15378],{"class":1060},"                baseline_value ",[1050,15380,1318],{"class":1089},[1050,15382,15306],{"class":1060},[1050,15384,1661],{"class":1089},[1050,15386,14390],{"class":1060},[1050,15388,2552],{"class":1089},[1050,15390,15391,15394,15396,15398,15400,15402],{"class":1052,"line":2766},[1050,15392,15393],{"class":1060},"                current_value ",[1050,15395,1318],{"class":1089},[1050,15397,15311],{"class":1060},[1050,15399,1661],{"class":1089},[1050,15401,14390],{"class":1060},[1050,15403,2552],{"class":1089},[1050,15405,15406],{"class":1052,"line":2780},[1050,15407,9526],{"class":1060},[1050,15409,15410],{"class":1052,"line":2792},[1050,15411,15412],{"class":1265},"                # Calculate percentage change\n",[1050,15414,15415,15417,15419,15421,15423,15425,15427],{"class":1052,"line":2808},[1050,15416,10882],{"class":1056},[1050,15418,15355],{"class":1060},[1050,15420,1912],{"class":1635},[1050,15422,1915],{"class":1401},[1050,15424,3197],{"class":1350},[1050,15426,1364],{"class":1401},[1050,15428,1847],{"class":1089},[1050,15430,15431],{"class":1052,"line":2824},[1050,15432,15433],{"class":1265},"                    # For success rate, lower is worse\n",[1050,15435,15436,15439,15441,15443,15446,15448,15451,15453,15455,15458,15460],{"class":1052,"line":2839},[1050,15437,15438],{"class":1060},"                    change ",[1050,15440,1318],{"class":1089},[1050,15442,5499],{"class":1089},[1050,15444,15445],{"class":1060},"baseline_value ",[1050,15447,2105],{"class":1635},[1050,15449,15450],{"class":1060}," current_value",[1050,15452,2619],{"class":1089},[1050,15454,3212],{"class":1635},[1050,15456,15457],{"class":1060}," baseline_value ",[1050,15459,8318],{"class":1635},[1050,15461,8321],{"class":1306},[1050,15463,15464,15467],{"class":1052,"line":2854},[1050,15465,15466],{"class":1056},"                else",[1050,15468,1847],{"class":1089},[1050,15470,15471],{"class":1052,"line":2880},[1050,15472,15473],{"class":1265},"                    # For response times, higher is worse\n",[1050,15475,15476,15478,15480,15482,15485,15487,15490,15492,15494,15496,15498],{"class":1052,"line":2886},[1050,15477,15438],{"class":1060},[1050,15479,1318],{"class":1089},[1050,15481,5499],{"class":1089},[1050,15483,15484],{"class":1060},"current_value ",[1050,15486,2105],{"class":1635},[1050,15488,15489],{"class":1060}," baseline_value",[1050,15491,2619],{"class":1089},[1050,15493,3212],{"class":1635},[1050,15495,15457],{"class":1060},[1050,15497,8318],{"class":1635},[1050,15499,8321],{"class":1306},[1050,15501,15502],{"class":1052,"line":2891},[1050,15503,9526],{"class":1060},[1050,15505,15506],{"class":1052,"line":2911},[1050,15507,15508],{"class":1265},"                # Check if regression exceeds threshold\n",[1050,15510,15511,15513,15516,15518,15520],{"class":1052,"line":2916},[1050,15512,10882],{"class":1056},[1050,15514,15515],{"class":1060}," change ",[1050,15517,6116],{"class":1635},[1050,15519,15316],{"class":1060},[1050,15521,1847],{"class":1089},[1050,15523,15524,15527,15529,15531,15533,15535],{"class":1052,"line":2935},[1050,15525,15526],{"class":1060},"                    regressions",[1050,15528,1661],{"class":1089},[1050,15530,14390],{"class":1060},[1050,15532,3020],{"class":1089},[1050,15534,1282],{"class":1089},[1050,15536,2064],{"class":1089},[1050,15538,15539,15541,15544,15546,15548,15550],{"class":1052,"line":2945},[1050,15540,2795],{"class":1401},[1050,15542,15543],{"class":1350},"baseline",[1050,15545,1364],{"class":1401},[1050,15547,2078],{"class":1089},[1050,15549,15489],{"class":1060},[1050,15551,1367],{"class":1089},[1050,15553,15554,15556,15559,15561,15563,15565],{"class":1052,"line":2950},[1050,15555,2795],{"class":1401},[1050,15557,15558],{"class":1350},"current",[1050,15560,1364],{"class":1401},[1050,15562,2078],{"class":1089},[1050,15564,15450],{"class":1060},[1050,15566,1367],{"class":1089},[1050,15568,15569,15571,15573,15575,15577],{"class":1052,"line":2962},[1050,15570,2795],{"class":1401},[1050,15572,14406],{"class":1350},[1050,15574,1364],{"class":1401},[1050,15576,2078],{"class":1089},[1050,15578,15579],{"class":1060}," change\n",[1050,15581,15582],{"class":1052,"line":2988},[1050,15583,6731],{"class":1089},[1050,15585,15586],{"class":1052,"line":2993},[1050,15587,1259],{"class":1060},[1050,15589,15590,15592],{"class":1052,"line":2999},[1050,15591,2894],{"class":1056},[1050,15593,15594],{"class":1060}," regressions\n",[1050,15596,15597],{"class":1052,"line":3034},[1050,15598,1224],{"class":1060},[1050,15600,15601,15603,15606,15608,15610],{"class":1052,"line":3074},[1050,15602,1230],{"class":1189},[1050,15604,15605],{"class":1233}," test_performance_alerting",[1050,15607,1197],{"class":1089},[1050,15609,1240],{"class":1239},[1050,15611,1204],{"class":1089},[1050,15613,15614,15616,15619],{"class":1052,"line":3110},[1050,15615,1248],{"class":1210},[1050,15617,15618],{"class":1214},"Test performance alerting system",[1050,15620,1218],{"class":1210},[1050,15622,15623],{"class":1052,"line":3115},[1050,15624,1259],{"class":1060},[1050,15626,15627],{"class":1052,"line":3121},[1050,15628,15629],{"class":1265},"        # Measure current performance\n",[1050,15631,15632,15635,15637,15639,15641,15643],{"class":1052,"line":3131},[1050,15633,15634],{"class":1060},"        current_metrics ",[1050,15636,1318],{"class":1089},[1050,15638,2481],{"class":1272},[1050,15640,1090],{"class":1089},[1050,15642,14262],{"class":1331},[1050,15644,1825],{"class":1089},[1050,15646,15647],{"class":1052,"line":3152},[1050,15648,1259],{"class":1060},[1050,15650,15651],{"class":1052,"line":3172},[1050,15652,15653],{"class":1265},"        # Check against thresholds\n",[1050,15655,15656,15659,15661],{"class":1052,"line":3192},[1050,15657,15658],{"class":1060},"        alerts ",[1050,15660,1318],{"class":1089},[1050,15662,1285],{"class":1089},[1050,15664,15665],{"class":1052,"line":3230},[1050,15666,1259],{"class":1060},[1050,15668,15669,15671,15673,15675,15678,15680,15682,15684,15686,15688,15690],{"class":1052,"line":3235},[1050,15670,1291],{"class":1056},[1050,15672,14359],{"class":1060},[1050,15674,1101],{"class":1089},[1050,15676,15677],{"class":1060}," threshold ",[1050,15679,1297],{"class":1056},[1050,15681,2481],{"class":1272},[1050,15683,1090],{"class":1089},[1050,15685,14117],{"class":1278},[1050,15687,1090],{"class":1089},[1050,15689,9802],{"class":1331},[1050,15691,2447],{"class":1089},[1050,15693,15694,15696,15698,15700,15703],{"class":1052,"line":3241},[1050,15695,1906],{"class":1056},[1050,15697,15355],{"class":1060},[1050,15699,1297],{"class":1635},[1050,15701,15702],{"class":1060}," current_metrics",[1050,15704,1847],{"class":1089},[1050,15706,15707,15710,15712,15714,15716,15718],{"class":1052,"line":3268},[1050,15708,15709],{"class":1060},"                value ",[1050,15711,1318],{"class":1089},[1050,15713,15702],{"class":1060},[1050,15715,1661],{"class":1089},[1050,15717,14390],{"class":1060},[1050,15719,2552],{"class":1089},[1050,15721,15722],{"class":1052,"line":3289},[1050,15723,9526],{"class":1060},[1050,15725,15726,15728,15730,15732,15734,15736,15738],{"class":1052,"line":3310},[1050,15727,10882],{"class":1056},[1050,15729,15355],{"class":1060},[1050,15731,1912],{"class":1635},[1050,15733,1915],{"class":1401},[1050,15735,3197],{"class":1350},[1050,15737,1364],{"class":1401},[1050,15739,1847],{"class":1089},[1050,15741,15742,15745,15748,15750,15752],{"class":1052,"line":3335},[1050,15743,15744],{"class":1056},"                    if",[1050,15746,15747],{"class":1060}," value ",[1050,15749,10647],{"class":1635},[1050,15751,15316],{"class":1060},[1050,15753,1847],{"class":1089},[1050,15755,15756,15759,15761,15763,15765,15767,15769,15771,15773,15775,15777,15779,15782,15784,15786,15789,15791,15794,15796,15799],{"class":1052,"line":3340},[1050,15757,15758],{"class":1060},"                        alerts",[1050,15760,1090],{"class":1089},[1050,15762,1428],{"class":1331},[1050,15764,1197],{"class":1089},[1050,15766,1347],{"class":1189},[1050,15768,2026],{"class":1350},[1050,15770,1355],{"class":1354},[1050,15772,14390],{"class":1331},[1050,15774,1361],{"class":1354},[1050,15776,9823],{"class":1350},[1050,15778,1355],{"class":1354},[1050,15780,15781],{"class":1331},"value",[1050,15783,4120],{"class":1189},[1050,15785,1361],{"class":1354},[1050,15787,15788],{"class":1350},"% (threshold: ",[1050,15790,1355],{"class":1354},[1050,15792,15793],{"class":1331},"threshold",[1050,15795,1361],{"class":1354},[1050,15797,15798],{"class":1350},"%)\"",[1050,15800,1436],{"class":1089},[1050,15802,15803,15805],{"class":1052,"line":3346},[1050,15804,15466],{"class":1056},[1050,15806,1847],{"class":1089},[1050,15808,15809,15811,15813,15815,15817],{"class":1052,"line":3376},[1050,15810,15744],{"class":1056},[1050,15812,15747],{"class":1060},[1050,15814,6116],{"class":1635},[1050,15816,15316],{"class":1060},[1050,15818,1847],{"class":1089},[1050,15820,15821,15823,15825,15827,15829,15831,15833,15835,15837,15839,15841,15843,15845,15847,15849,15852,15854,15856,15858,15861],{"class":1052,"line":3405},[1050,15822,15758],{"class":1060},[1050,15824,1090],{"class":1089},[1050,15826,1428],{"class":1331},[1050,15828,1197],{"class":1089},[1050,15830,1347],{"class":1189},[1050,15832,2026],{"class":1350},[1050,15834,1355],{"class":1354},[1050,15836,14390],{"class":1331},[1050,15838,1361],{"class":1354},[1050,15840,9823],{"class":1350},[1050,15842,1355],{"class":1354},[1050,15844,15781],{"class":1331},[1050,15846,4156],{"class":1189},[1050,15848,1361],{"class":1354},[1050,15850,15851],{"class":1350}," (threshold: ",[1050,15853,1355],{"class":1354},[1050,15855,15793],{"class":1331},[1050,15857,1361],{"class":1354},[1050,15859,15860],{"class":1350},")\"",[1050,15862,1436],{"class":1089},[1050,15864,15865],{"class":1052,"line":3410},[1050,15866,1259],{"class":1060},[1050,15868,15869,15871,15874],{"class":1052,"line":3416},[1050,15870,1842],{"class":1056},[1050,15872,15873],{"class":1060}," alerts",[1050,15875,1847],{"class":1089},[1050,15877,15878,15880,15882,15884,15887,15889],{"class":1052,"line":3457},[1050,15879,5392],{"class":1300},[1050,15881,1197],{"class":1089},[1050,15883,2026],{"class":1401},[1050,15885,15886],{"class":1350},"Performance Alerts:",[1050,15888,2026],{"class":1401},[1050,15890,1436],{"class":1089},[1050,15892,15893,15895,15898,15900,15902],{"class":1052,"line":3462},[1050,15894,2693],{"class":1056},[1050,15896,15897],{"class":1060}," alert ",[1050,15899,1297],{"class":1056},[1050,15901,15873],{"class":1060},[1050,15903,1847],{"class":1089},[1050,15905,15906,15908,15910,15912,15915,15917,15920,15922,15924],{"class":1052,"line":3468},[1050,15907,5624],{"class":1300},[1050,15909,1197],{"class":1089},[1050,15911,1347],{"class":1189},[1050,15913,15914],{"class":1350},"\"  ALERT: ",[1050,15916,1355],{"class":1354},[1050,15918,15919],{"class":1331},"alert",[1050,15921,1361],{"class":1354},[1050,15923,2026],{"class":1350},[1050,15925,1436],{"class":1089},[1050,15927,15928,15930],{"class":1052,"line":3518},[1050,15929,14424],{"class":1056},[1050,15931,1847],{"class":1089},[1050,15933,15934,15936,15938,15940,15943,15945],{"class":1052,"line":3543},[1050,15935,5392],{"class":1300},[1050,15937,1197],{"class":1089},[1050,15939,2026],{"class":1401},[1050,15941,15942],{"class":1350},"All performance metrics within thresholds",[1050,15944,2026],{"class":1401},[1050,15946,1436],{"class":1089},[1050,15948,15949],{"class":1052,"line":3549},[1050,15950,1259],{"class":1060},[1050,15952,15953],{"class":1052,"line":3554},[1050,15954,15955],{"class":1265},"        # In a real system, you would send these alerts to monitoring systems\n",[1050,15957,15958],{"class":1052,"line":3562},[1050,15959,15960],{"class":1265},"        # like Datadog, New Relic, or custom alerting systems\n",[1030,15962,15964],{"id":15963},"next-steps","Next Steps",[1026,15966,15967],{},"Performance testing is an ongoing process that should be integrated into your development workflow. Consider implementing:",[15969,15970,15971,15979,15985,15991,15997],"ul",{},[15972,15973,15974,15978],"li",{},[15975,15976,15977],"strong",{},"Continuous Performance Testing",": Integrate performance tests into your CI/CD pipeline",[15972,15980,15981,15984],{},[15975,15982,15983],{},"Real User Monitoring (RUM)",": Monitor actual user performance in production",[15972,15986,15987,15990],{},[15975,15988,15989],{},"Application Performance Monitoring (APM)",": Use tools like New Relic, Datadog, or Sentry",[15972,15992,15993,15996],{},[15975,15994,15995],{},"Load Testing in Staging",": Regular load testing in staging environments",[15972,15998,15999,16002],{},[15975,16000,16001],{},"Performance Budgets",": Set and enforce performance budgets for your application",[1026,16004,16005],{},"Key performance testing concepts covered:",[15969,16007,16008,16011,16014,16017,16020],{},[15972,16009,16010],{},"Load testing fundamentals and stress testing",[15972,16012,16013],{},"Database query performance optimization",[15972,16015,16016],{},"Caching effectiveness analysis",[15972,16018,16019],{},"Frontend performance testing",[15972,16021,16022],{},"Performance monitoring and regression detection",[1026,16024,16025],{},"With comprehensive testing knowledge now complete, you have the tools to ensure your Django application is reliable, secure, and performant across all aspects of development and deployment.",[16027,16028,16029],"style",{},"html pre.shiki code .siDh9, html code.shiki .siDh9{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#1E754F;--shiki-default-font-style:inherit;--shiki-dark:#4D9375;--shiki-dark-font-style:inherit}html pre.shiki code .sftqT, html code.shiki .sftqT{--shiki-light:#90A4AE;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .soVBu, html code.shiki .soVBu{--shiki-light:#39ADB5;--shiki-default:#999999;--shiki-dark:#666666}html pre.shiki code .s5Kfy, html code.shiki .s5Kfy{--shiki-light:#9C3EDA;--shiki-default:#AB5959;--shiki-dark:#CB7676}html pre.shiki code .sD-vU, html code.shiki .sD-vU{--shiki-light:#E2931D;--shiki-default:#2E8F82;--shiki-dark:#5DA994}html pre.shiki code .sYn-s, html code.shiki .sYn-s{--shiki-light:#E2931D;--shiki-default:#59873A;--shiki-dark:#80A665}html pre.shiki code .sm7ve, html code.shiki .sm7ve{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#B5695977;--shiki-default-font-style:inherit;--shiki-dark:#C98A7D77;--shiki-dark-font-style:inherit}html pre.shiki code .sVyVU, html code.shiki .sVyVU{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#B56959;--shiki-default-font-style:inherit;--shiki-dark:#C98A7D;--shiki-dark-font-style:inherit}html pre.shiki code .sljsM, html code.shiki .sljsM{--shiki-light:#6182B8;--shiki-default:#59873A;--shiki-dark:#80A665}html pre.shiki code .sRjD_, html code.shiki .sRjD_{--shiki-light:#E53935;--shiki-light-font-style:italic;--shiki-default:#393A34;--shiki-default-font-style:inherit;--shiki-dark:#DBD7CAEE;--shiki-dark-font-style:inherit}html pre.shiki code .s9Tkl, html code.shiki .s9Tkl{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#A0ADA0;--shiki-default-font-style:inherit;--shiki-dark:#758575DD;--shiki-dark-font-style:inherit}html pre.shiki code .se3Ec, html code.shiki .se3Ec{--shiki-light:#90A4AE;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .sBPpx, html code.shiki .sBPpx{--shiki-light:#E53935;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .sJdAF, html code.shiki .sJdAF{--shiki-light:#6182B8;--shiki-default:#998418;--shiki-dark:#B8A965}html pre.shiki code .s7CZa, html code.shiki .s7CZa{--shiki-light:#F76D47;--shiki-default:#2F798A;--shiki-dark:#4C9A91}html pre.shiki code .siWMO, html code.shiki .siWMO{--shiki-light:#6182B8;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .sqOPj, html code.shiki .sqOPj{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#B07D48;--shiki-default-font-style:inherit;--shiki-dark:#BD976A;--shiki-dark-font-style:inherit}html pre.shiki code .sTbE_, html code.shiki .sTbE_{--shiki-light:#91B859;--shiki-default:#B56959;--shiki-dark:#C98A7D}html pre.shiki code .s3h35, html code.shiki .s3h35{--shiki-light:#F76D47;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .sbYkP, html code.shiki .sbYkP{--shiki-light:#39ADB5;--shiki-default:#B5695977;--shiki-dark:#C98A7D77}html pre.shiki code .sVsLi, html code.shiki .sVsLi{--shiki-light:#39ADB5;--shiki-default:#AB5959;--shiki-dark:#CB7676}html pre.shiki code .sCyAa, html code.shiki .sCyAa{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#393A34;--shiki-default-font-style:inherit;--shiki-dark:#DBD7CAEE;--shiki-dark-font-style:inherit}html pre.shiki code .s8XtY, html code.shiki .s8XtY{--shiki-light:#39ADB5;--shiki-default:#1E754F;--shiki-dark:#4D9375}html pre.shiki code .sa2tF, html code.shiki .sa2tF{--shiki-light:#E2931D;--shiki-default:#998418;--shiki-dark:#B8A965}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}",{"title":1045,"searchDepth":1053,"depth":1064,"links":16031},[16032,16035,16038,16041,16044,16047,16050],{"id":1032,"depth":1064,"text":1033,"children":16033},[16034],{"id":1037,"depth":1072,"text":1038},{"id":5193,"depth":1064,"text":5194,"children":16036},[16037],{"id":5197,"depth":1072,"text":5198},{"id":6916,"depth":1064,"text":6917,"children":16039},[16040],{"id":6920,"depth":1072,"text":6921},{"id":9954,"depth":1064,"text":9955,"children":16042},[16043],{"id":9958,"depth":1072,"text":9959},{"id":12399,"depth":1064,"text":12400,"children":16045},[16046],{"id":12403,"depth":1072,"text":12404},{"id":14060,"depth":1064,"text":14061,"children":16048},[16049],{"id":14064,"depth":1072,"text":14065},{"id":15963,"depth":1064,"text":15964},"md",null,{},{"title":621,"description":1028},"Kodv1B1kSPAVHsVWBU6ejTa_5cLVRVC9NJD_nqg9j_0",[16057,16059],{"title":617,"path":618,"stem":619,"description":16058,"children":-1},"Advanced testing techniques help you handle complex scenarios, improve test reliability, and ensure comprehensive coverage of your Django application. This chapter covers sophisticated testing patterns, mocking strategies, async testing, and integration with external services.",{"title":625,"path":626,"stem":627,"description":16060,"children":-1},"Modern web applications require sophisticated frontend capabilities, from basic CSS and JavaScript to complex single-page applications (SPAs) built with frameworks like React or Vue. Django provides robust support for managing static assets and integrating with modern frontend toolchains, enabling you to build full-stack applications that deliver exceptional user experiences.",1772474943368]