feat(app): add manual entry and sharing flows

This commit is contained in:
JiWoong Sul
2025-11-19 16:36:39 +09:00
parent 5ade584370
commit 947fe59486
110 changed files with 5937 additions and 3781 deletions

View File

@@ -1,3 +1,4 @@
@Skip('Requires live Naver API responses')
import 'package:flutter_test/flutter_test.dart';
import 'package:lunchpick/data/api/naver_api_client.dart';
import 'package:lunchpick/data/datasources/remote/naver_map_parser.dart';
@@ -21,14 +22,14 @@ void main() {
test('단축 URL 자동 처리 테스트', () async {
// 실제 단축 URL로 테스트
const shortUrl = 'https://naver.me/example'; // 실제 URL로 교체 필요
try {
print('========== 단축 URL 자동 처리 테스트 ==========');
print('입력 URL: $shortUrl');
// NaverMapParser를 통한 자동 처리
final restaurant = await parser.parseRestaurantFromUrl(shortUrl);
print('\n【파싱 결과】');
print('상호명: ${restaurant.name}');
print('카테고리: ${restaurant.category} > ${restaurant.subCategory}');
@@ -38,14 +39,14 @@ void main() {
print('좌표: ${restaurant.latitude}, ${restaurant.longitude}');
print('Place ID: ${restaurant.naverPlaceId}');
print('URL: ${restaurant.naverUrl}');
// 검증
expect(restaurant.name, isNotEmpty);
expect(restaurant.category, isNotEmpty);
expect(restaurant.roadAddress, isNotEmpty);
expect(restaurant.naverPlaceId, isNotEmpty);
expect(restaurant.source.name, equals('NAVER'));
print('\n✓ 테스트 성공');
} catch (e) {
print('\n❌ 테스트 실패: $e');
@@ -71,36 +72,37 @@ void main() {
</body>
</html>
''';
print('\n========== HTML 추출기 테스트 ==========');
// 한글 텍스트 추출
final koreanTexts = NaverHtmlExtractor.extractAllValidKoreanTexts(testHtml);
final koreanTexts = NaverHtmlExtractor.extractAllValidKoreanTexts(
testHtml,
);
print('추출된 한글 텍스트: $koreanTexts');
expect(koreanTexts, isNotEmpty);
// JSON-LD 추출
final jsonLdName = NaverHtmlExtractor.extractPlaceNameFromJsonLd(testHtml);
final jsonLdName = NaverHtmlExtractor.extractPlaceNameFromJsonLd(
testHtml,
);
print('JSON-LD 상호명: $jsonLdName');
expect(jsonLdName, equals('테스트 식당'));
print('\n✓ 테스트 성공');
});
test('로컬 검색 API 테스트', () async {
print('\n========== 로컬 검색 API 테스트 ==========');
const query = '스타벅스 강남역점';
try {
final results = await apiClient.searchLocal(
query: query,
display: 5,
);
final results = await apiClient.searchLocal(query: query, display: 5);
print('검색어: "$query"');
print('결과 수: ${results.length}\n');
for (int i = 0; i < results.length; i++) {
final result = results[i];
print('${i + 1}. ${result.title}');
@@ -108,7 +110,7 @@ void main() {
print(' 주소: ${result.roadAddress}');
print(' 좌표: ${result.mapx}, ${result.mapy}');
}
expect(results, isNotEmpty);
print('\n✓ 테스트 성공');
} catch (e) {
@@ -119,21 +121,21 @@ void main() {
test('성능 테스트 - 단축 URL 처리 시간', () async {
const shortUrl = 'https://naver.me/example'; // 실제 URL로 교체 필요
print('\n========== 성능 테스트 ==========');
final stopwatch = Stopwatch()..start();
try {
final restaurant = await parser.parseRestaurantFromUrl(shortUrl);
stopwatch.stop();
print('처리 완료: ${restaurant.name}');
print('소요 시간: ${stopwatch.elapsedMilliseconds}ms');
// 5초 이내 처리 확인
expect(stopwatch.elapsedMilliseconds, lessThan(5000));
print('\n✓ 테스트 성공');
} catch (e) {
stopwatch.stop();
@@ -143,4 +145,4 @@ void main() {
}
});
});
}
}