| OLD | NEW |
| 1 // Copyright 2010 the V8 project authors. All rights reserved. | 1 // Copyright 2010 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 212 top_down_stub_children->last()->children(); | 212 top_down_stub_children->last()->children(); |
| 213 CHECK_EQ(0, top_down_ddd_children->length()); | 213 CHECK_EQ(0, top_down_ddd_children->length()); |
| 214 } | 214 } |
| 215 | 215 |
| 216 | 216 |
| 217 // http://crbug/51594 | 217 // http://crbug/51594 |
| 218 // This test must not crash. | 218 // This test must not crash. |
| 219 TEST(CrashIfStoppingLastNonExistentProfile) { | 219 TEST(CrashIfStoppingLastNonExistentProfile) { |
| 220 InitializeVM(); | 220 InitializeVM(); |
| 221 TestSetup test_setup; | 221 TestSetup test_setup; |
| 222 CpuProfiler::SetUp(); | 222 CpuProfiler* profiler = i::Isolate::Current()->cpu_profiler(); |
| 223 CpuProfiler::StartProfiling("1"); | 223 profiler->StartProfiling("1"); |
| 224 CpuProfiler::StopProfiling("2"); | 224 profiler->StopProfiling("2"); |
| 225 CpuProfiler::StartProfiling("1"); | 225 profiler->StartProfiling("1"); |
| 226 CpuProfiler::StopProfiling(""); | 226 profiler->StopProfiling(""); |
| 227 CpuProfiler::TearDown(); | |
| 228 } | 227 } |
| 229 | 228 |
| 230 | 229 |
| 231 // http://code.google.com/p/v8/issues/detail?id=1398 | 230 // http://code.google.com/p/v8/issues/detail?id=1398 |
| 232 // Long stacks (exceeding max frames limit) must not be erased. | 231 // Long stacks (exceeding max frames limit) must not be erased. |
| 233 TEST(Issue1398) { | 232 TEST(Issue1398) { |
| 234 TestSetup test_setup; | 233 TestSetup test_setup; |
| 235 CpuProfilesCollection profiles; | 234 CpuProfilesCollection profiles; |
| 236 profiles.StartProfiling("", 1, false); | 235 profiles.StartProfiling("", 1, false); |
| 237 ProfileGenerator generator(&profiles); | 236 ProfileGenerator generator(&profiles); |
| (...skipping 26 matching lines...) Expand all Loading... |
| 264 ++actual_depth; | 263 ++actual_depth; |
| 265 } | 264 } |
| 266 | 265 |
| 267 CHECK_EQ(1 + i::TickSample::kMaxFramesCount, actual_depth); // +1 for PC. | 266 CHECK_EQ(1 + i::TickSample::kMaxFramesCount, actual_depth); // +1 for PC. |
| 268 } | 267 } |
| 269 | 268 |
| 270 | 269 |
| 271 TEST(DeleteAllCpuProfiles) { | 270 TEST(DeleteAllCpuProfiles) { |
| 272 InitializeVM(); | 271 InitializeVM(); |
| 273 TestSetup test_setup; | 272 TestSetup test_setup; |
| 274 CpuProfiler::SetUp(); | 273 CpuProfiler* profiler = i::Isolate::Current()->cpu_profiler(); |
| 275 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 274 CHECK_EQ(0, profiler->GetProfilesCount()); |
| 276 CpuProfiler::DeleteAllProfiles(); | 275 profiler->DeleteAllProfiles(); |
| 277 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 276 CHECK_EQ(0, profiler->GetProfilesCount()); |
| 278 | 277 |
| 279 CpuProfiler::StartProfiling("1"); | 278 profiler->StartProfiling("1"); |
| 280 CpuProfiler::StopProfiling("1"); | 279 profiler->StopProfiling("1"); |
| 281 CHECK_EQ(1, CpuProfiler::GetProfilesCount()); | 280 CHECK_EQ(1, profiler->GetProfilesCount()); |
| 282 CpuProfiler::DeleteAllProfiles(); | 281 profiler->DeleteAllProfiles(); |
| 283 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 282 CHECK_EQ(0, profiler->GetProfilesCount()); |
| 284 CpuProfiler::StartProfiling("1"); | 283 profiler->StartProfiling("1"); |
| 285 CpuProfiler::StartProfiling("2"); | 284 profiler->StartProfiling("2"); |
| 286 CpuProfiler::StopProfiling("2"); | 285 profiler->StopProfiling("2"); |
| 287 CpuProfiler::StopProfiling("1"); | 286 profiler->StopProfiling("1"); |
| 288 CHECK_EQ(2, CpuProfiler::GetProfilesCount()); | 287 CHECK_EQ(2, profiler->GetProfilesCount()); |
| 289 CpuProfiler::DeleteAllProfiles(); | 288 profiler->DeleteAllProfiles(); |
| 290 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 289 CHECK_EQ(0, profiler->GetProfilesCount()); |
| 291 | 290 |
| 292 // Test profiling cancellation by the 'delete' command. | 291 // Test profiling cancellation by the 'delete' command. |
| 293 CpuProfiler::StartProfiling("1"); | 292 profiler->StartProfiling("1"); |
| 294 CpuProfiler::StartProfiling("2"); | 293 profiler->StartProfiling("2"); |
| 295 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 294 CHECK_EQ(0, profiler->GetProfilesCount()); |
| 296 CpuProfiler::DeleteAllProfiles(); | 295 profiler->DeleteAllProfiles(); |
| 297 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 296 CHECK_EQ(0, profiler->GetProfilesCount()); |
| 298 | |
| 299 CpuProfiler::TearDown(); | |
| 300 } | 297 } |
| 301 | 298 |
| 302 | 299 |
| 303 TEST(DeleteCpuProfile) { | 300 TEST(DeleteCpuProfile) { |
| 304 LocalContext env; | 301 LocalContext env; |
| 305 v8::HandleScope scope(env->GetIsolate()); | 302 v8::HandleScope scope(env->GetIsolate()); |
| 306 | 303 |
| 307 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); | 304 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); |
| 308 v8::Local<v8::String> name1 = v8::String::New("1"); | 305 v8::Local<v8::String> name1 = v8::String::New("1"); |
| 309 v8::CpuProfiler::StartProfiling(name1); | 306 v8::CpuProfiler::StartProfiling(name1); |
| 310 const v8::CpuProfile* p1 = v8::CpuProfiler::StopProfiling(name1); | 307 const v8::CpuProfile* p1 = v8::CpuProfiler::StopProfiling(name1); |
| 311 CHECK_NE(NULL, p1); | 308 CHECK_NE(NULL, p1); |
| 312 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 309 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 313 unsigned uid1 = p1->GetUid(); | 310 unsigned uid1 = p1->GetUid(); |
| 314 CHECK_EQ(p1, v8::CpuProfiler::FindProfile(uid1)); | 311 CHECK_EQ(p1, v8::CpuProfiler::FindProfile(uid1)); |
| 315 const_cast<v8::CpuProfile*>(p1)->Delete(); | 312 const_cast<v8::CpuProfile*>(p1)->Delete(); |
| 316 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 313 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); |
| 317 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); | 314 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); |
| 318 | 315 |
| 319 v8::Local<v8::String> name2 = v8::String::New("2"); | 316 v8::Local<v8::String> name2 = v8::String::New("2"); |
| 320 v8::CpuProfiler::StartProfiling(name2); | 317 v8::CpuProfiler::StartProfiling(name2); |
| 321 const v8::CpuProfile* p2 = v8::CpuProfiler::StopProfiling(name2); | 318 const v8::CpuProfile* p2 = v8::CpuProfiler::StopProfiling(name2); |
| 322 CHECK_NE(NULL, p2); | 319 CHECK_NE(NULL, p2); |
| 323 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 320 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 324 unsigned uid2 = p2->GetUid(); | 321 unsigned uid2 = p2->GetUid(); |
| 325 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid2)); | 322 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid2)); |
| 326 CHECK_EQ(p2, v8::CpuProfiler::FindProfile(uid2)); | 323 CHECK_EQ(p2, v8::CpuProfiler::FindProfile(uid2)); |
| 327 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); | 324 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); |
| 328 v8::Local<v8::String> name3 = v8::String::New("3"); | 325 v8::Local<v8::String> name3 = v8::String::New("3"); |
| 329 v8::CpuProfiler::StartProfiling(name3); | 326 v8::CpuProfiler::StartProfiling(name3); |
| 330 const v8::CpuProfile* p3 = v8::CpuProfiler::StopProfiling(name3); | 327 const v8::CpuProfile* p3 = v8::CpuProfiler::StopProfiling(name3); |
| 331 CHECK_NE(NULL, p3); | 328 CHECK_NE(NULL, p3); |
| 332 CHECK_EQ(2, v8::CpuProfiler::GetProfilesCount()); | 329 CHECK_EQ(2, v8::CpuProfiler::GetProfilesCount()); |
| 333 unsigned uid3 = p3->GetUid(); | 330 unsigned uid3 = p3->GetUid(); |
| 334 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid3)); | 331 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid3)); |
| 335 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); | 332 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); |
| 336 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); | 333 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); |
| 337 const_cast<v8::CpuProfile*>(p2)->Delete(); | 334 const_cast<v8::CpuProfile*>(p2)->Delete(); |
| 338 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 335 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 339 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); | 336 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); |
| 340 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); | 337 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); |
| 341 const_cast<v8::CpuProfile*>(p3)->Delete(); | 338 const_cast<v8::CpuProfile*>(p3)->Delete(); |
| 342 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 339 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); |
| 343 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid3)); | 340 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid3)); |
| 344 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); | 341 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); |
| 345 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); | 342 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); |
| 346 } | 343 } |
| 347 | 344 |
| 348 | 345 |
| 349 TEST(DeleteCpuProfileDifferentTokens) { | 346 TEST(DeleteCpuProfileDifferentTokens) { |
| 350 LocalContext env; | 347 LocalContext env; |
| 351 v8::HandleScope scope(env->GetIsolate()); | 348 v8::HandleScope scope(env->GetIsolate()); |
| 352 | 349 |
| 353 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); | 350 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); |
| 354 v8::Local<v8::String> name1 = v8::String::New("1"); | 351 v8::Local<v8::String> name1 = v8::String::New("1"); |
| 355 v8::CpuProfiler::StartProfiling(name1); | 352 v8::CpuProfiler::StartProfiling(name1); |
| 356 const v8::CpuProfile* p1 = v8::CpuProfiler::StopProfiling(name1); | 353 const v8::CpuProfile* p1 = v8::CpuProfiler::StopProfiling(name1); |
| 357 CHECK_NE(NULL, p1); | 354 CHECK_NE(NULL, p1); |
| 358 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 355 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 359 unsigned uid1 = p1->GetUid(); | 356 unsigned uid1 = p1->GetUid(); |
| 360 CHECK_EQ(p1, v8::CpuProfiler::FindProfile(uid1)); | 357 CHECK_EQ(p1, v8::CpuProfiler::FindProfile(uid1)); |
| 361 v8::Local<v8::String> token1 = v8::String::New("token1"); | 358 v8::Local<v8::String> token1 = v8::String::New("token1"); |
| 362 const v8::CpuProfile* p1_t1 = v8::CpuProfiler::FindProfile(uid1, token1); | 359 const v8::CpuProfile* p1_t1 = v8::CpuProfiler::FindProfile(uid1, token1); |
| 363 CHECK_NE(NULL, p1_t1); | 360 CHECK_NE(NULL, p1_t1); |
| 364 CHECK_NE(p1, p1_t1); | 361 CHECK_NE(p1, p1_t1); |
| 365 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 362 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 366 const_cast<v8::CpuProfile*>(p1)->Delete(); | 363 const_cast<v8::CpuProfile*>(p1)->Delete(); |
| 367 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 364 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); |
| 368 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); | 365 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1)); |
| 369 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1, token1)); | 366 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid1, token1)); |
| 370 const_cast<v8::CpuProfile*>(p1_t1)->Delete(); | 367 const_cast<v8::CpuProfile*>(p1_t1)->Delete(); |
| 371 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 368 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); |
| 372 | 369 |
| 373 v8::Local<v8::String> name2 = v8::String::New("2"); | 370 v8::Local<v8::String> name2 = v8::String::New("2"); |
| 374 v8::CpuProfiler::StartProfiling(name2); | 371 v8::CpuProfiler::StartProfiling(name2); |
| 375 v8::Local<v8::String> token2 = v8::String::New("token2"); | 372 v8::Local<v8::String> token2 = v8::String::New("token2"); |
| 376 const v8::CpuProfile* p2_t2 = v8::CpuProfiler::StopProfiling(name2, token2); | 373 const v8::CpuProfile* p2_t2 = v8::CpuProfiler::StopProfiling(name2, token2); |
| 377 CHECK_NE(NULL, p2_t2); | 374 CHECK_NE(NULL, p2_t2); |
| 378 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 375 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 379 unsigned uid2 = p2_t2->GetUid(); | 376 unsigned uid2 = p2_t2->GetUid(); |
| 380 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid2)); | 377 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid2)); |
| 381 const v8::CpuProfile* p2 = v8::CpuProfiler::FindProfile(uid2); | 378 const v8::CpuProfile* p2 = v8::CpuProfiler::FindProfile(uid2); |
| 382 CHECK_NE(p2_t2, p2); | 379 CHECK_NE(p2_t2, p2); |
| 383 v8::Local<v8::String> name3 = v8::String::New("3"); | 380 v8::Local<v8::String> name3 = v8::String::New("3"); |
| 384 v8::CpuProfiler::StartProfiling(name3); | 381 v8::CpuProfiler::StartProfiling(name3); |
| 385 const v8::CpuProfile* p3 = v8::CpuProfiler::StopProfiling(name3); | 382 const v8::CpuProfile* p3 = v8::CpuProfiler::StopProfiling(name3); |
| 386 CHECK_NE(NULL, p3); | 383 CHECK_NE(NULL, p3); |
| 387 CHECK_EQ(2, v8::CpuProfiler::GetProfilesCount()); | 384 CHECK_EQ(2, v8::CpuProfiler::GetProfilesCount()); |
| 388 unsigned uid3 = p3->GetUid(); | 385 unsigned uid3 = p3->GetUid(); |
| 389 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid3)); | 386 CHECK_NE(static_cast<int>(uid1), static_cast<int>(uid3)); |
| 390 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); | 387 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); |
| 391 const_cast<v8::CpuProfile*>(p2_t2)->Delete(); | 388 const_cast<v8::CpuProfile*>(p2_t2)->Delete(); |
| 392 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 389 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 393 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); | 390 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); |
| 394 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); | 391 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); |
| 395 const_cast<v8::CpuProfile*>(p2)->Delete(); | 392 const_cast<v8::CpuProfile*>(p2)->Delete(); |
| 396 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); | 393 CHECK_EQ(1, v8::CpuProfiler::GetProfilesCount()); |
| 397 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); | 394 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid2)); |
| 398 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); | 395 CHECK_EQ(p3, v8::CpuProfiler::FindProfile(uid3)); |
| 399 const_cast<v8::CpuProfile*>(p3)->Delete(); | 396 const_cast<v8::CpuProfile*>(p3)->Delete(); |
| 400 CHECK_EQ(0, CpuProfiler::GetProfilesCount()); | 397 CHECK_EQ(0, v8::CpuProfiler::GetProfilesCount()); |
| 401 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid3)); | 398 CHECK_EQ(NULL, v8::CpuProfiler::FindProfile(uid3)); |
| 402 } | 399 } |
| OLD | NEW |