이 항목은 아직 평가되지 않았습니다.- 이 항목 평가

Windows Phone 8용 앱에서 바로 구매 테스트

2013-12-05

적용 대상: Windows Phone 8 전용입니다.

 

앱에서 바로 구매는 앱 사용자에게 Windows Phone 8 앱 내에서 항목을 구매하는 기능을 제공하는 Windows Phone 8 의 새로운 기능입니다. 구매용으로 앱을 게시하기 전에 앱의 앱에서 바로 구매 기능을 테스트하기 위한 세 가지 옵션이 제공됩니다.

다음 기술 중 하나를 수행하여 Windows Phone 앱에서 바로 구매를 테스트할 수 있습니다.

앱의 앱에서 바로 구매 기능을 테스트하는 한 가지 방법은 개발자 센터 베타 앱을 만들고 베타 앱 내 제품을 추가하는 것입니다. Windows Phone 개발자 센터 에서 앱을 Windows Phone 스토어 에 베타 앱으로 업로드할 수 있습니다. 그런 다음 베타 앱 내 제품을 앱에 추가합니다. 베타 앱을 사용하여 앱에서 바로 구매 프로세스를 테스트합니다.

개발자 센터 베타 앱을 만들어서 앱에서 바로 구매를 테스트하는 대신 모의 앱에서 바로 구매 라이브러리를 솔루션에 추가할 수 있습니다. Visual Studio에서 모의 앱에서 바로 구매 라이브러리를 솔루션에 추가적인 프로젝트로 추가합니다. 이 라이브러리에는 에뮬레이터를 사용하여 앱의 앱에서 바로 구매 기능을 테스트하는 데 사용할 수 있는 모의 앱에서 바로 구매 기능이 포함됩니다. 앱을 로컬로 테스트할 경우 모의 라이브러리에 포함된 함수를 호출하려면 앱을 수정해야 합니다.

이 간단한 모의 라이브러리는 실제 서비스를 설정할 필요 없이 앱에서 바로 구매를 더욱 쉽게 사용할 수 있도록 디자인되어 있습니다. 라이브러리는 앱에서 바로 구매 API를 둘러싼 씬 래퍼입니다. 라이브러리를 초기화하는 방법에 따라 테스트 대상으로 정의한 제품의 모든 응답을 모형화하거나 라이브 앱에서 바로 구매 API에 대한 모든 호출을 통과합니다. 이렇게 하면 플래그 값 변경에 따라 실제 API나 모의 API를 사용하여 다양한 테스트 시나리오를 대상으로 지정할 수 있습니다.

라이브러리는 앱에서 바로 구매가 작동하는 방식을 모방하도록 디자인되어 있습니다. "모의 모드"에서 라이브러리는 모든 라이선스에 대한 상태 정보 및 영수증 목록을 유지 관리합니다. 이를 통해 전체 찾아보기, 검색, 구매 및 주문 처리 흐름을 연습할 수 있습니다. "모의 모드"에서 라이브러리는 모의 앱에서 바로 구매 화면을 활성화하지 않지만 에뮬레이터에서 테스트하는 동안 앱에서 바로 구매 흐름을 완료하도록 단순 메시지 상자를 제공합니다.

모의 앱에서 바로 구매 라이브러리 및 샘플 앱 다운로드

모의 앱에서 바로 구매 라이브러리에서 모의 앱에서 바로 구매 라이브러리 및 샘플 앱을 다운로드합니다.

모의 앱에서 바로 구매 라이브러리 사용

모의 앱에서 바로 구매 라이브러리는 C# 코드로 작성됩니다.

앱에서 바로 구매 기능을 사용하는 각 .cs 파일에 다음 using 문 코드 블록을 포함합니다.

#if DEBUG
using MockIAPLib;
using Store = MockIAPLib;
#else
using Windows.ApplicationModel.Store;
#endif

이 문을 사용하면 모의 라이브러리를 사용하여 앱에서 바로 구매를 테스트하거나 게시된 앱으로 실제 앱에서 바로 구매를 호출하도록 전환할 수 있습니다. 테스트할 때 디버그 모드에서 앱을 빌드해야 합니다. 디버그 모드의 경우 Visual Studio의 솔루션 구성 드롭다운 목록에서 디버그를 클릭합니다. Windows Phone 스토어 배포를 위해 앱을 빌드할 준비가 되면 솔루션 구성 드롭다운 목록에서 릴리스를 선택하여 릴리스 모드로 변경합니다.

모의 라이브러리를 초기화하려면 다음 코드를 App.xaml.cs 파일의 App 생성자 끝 부분에 추가합니다.

            SetupMockIAP();

그런 다음 SetupMockIAP 메서드를 추가하여 모의 라이브러리를 초기화하고 모의 제품을 추가합니다. 샘플 SetupMockIAP 메서드가 다음과 같이 표시됩니다.

        private void SetupMockIAP()
        {
#if DEBUG
            MockIAP.Init();

            MockIAP.RunInMockMode(true);
            MockIAP.SetListingInformation(1, "en-us", "A description", "1", "TestApp");

            // Add some more items manually.
            ProductListing p = new ProductListing
            {
                Name = "img.2",
                ImageUri = new Uri("/Res/Image/2.jpg", UriKind.Relative),
                ProductId = "img.2",
                ProductType = Windows.ApplicationModel.Store.ProductType.Durable,
                Keywords = new string[] { "image" },
                Description = "An image",
                FormattedPrice = "1.0",
                Tag = string.Empty
            };
            MockIAP.AddProductListing("img.2", p);
#endif
        }

메서드에 포함된 코드는 프로젝트가 디버그 모드에서 실행되는 경우에만 실행됩니다.

앱에서 바로 구매 제품을 채우는 다른 방법은 테스트에 사용하려는 모든 제안을 나열하는 XML 조각을 사용하는 것입니다.

XML이 다음과 같이 표시됩니다.

<?xml version="1.0"?>
<ProductListings>
    <ProductListing Key="test1" Purchased="true" Fulfilled="true">
        <Name>Testproduct</Name>
        <Description>A sample product listing</Description>
        <ProductId>test.durable.1</ProductId>
        <ProductType>Durable</ProductType>
        <FormattedPrice>$1.00</FormattedPrice>
        <ImageUri></ImageUri>
        <Keywords>test;product</Keywords>
        <Tag>Additional text</Tag>
    </ProductListing>
</ProductListings>

이 XML을 "모의 저장소"에 로드하려면 다음 메서드 호출을 사용합니다.

MockIAP.PopulateIAPItemsFromXml(Xml);

참고참고:

XML 형식을 사용할 경우 항목이 PurchasedFulfilled인지 미리 설정하려면 이러한 특성을 true 또는 false로 설정합니다.

다음 코드에서는 테스트할 제품을 로드하는 방법을 보여 줍니다.

ListingInformation li = await CurrentApp.LoadListingInformationAsync();
참고참고:

이 함수 호출은 모의 라이브러리를 사용하여 테스트할 경우와 게시된 앱으로 실행할 경우 모두 동일합니다. 라이브러리에는 영수증, 상태 정보와 같은 데이터의 모의 캐시를 지우는 데 사용할 수 있는 API가 있습니다. MockIAP.ClearCache 메서드를 호출하여 모의 캐시를 지웁니다.

모의 라이브러리 사용에 대한 자세한 내용을 보려면 이 항목의 모의 앱에서 바로 구매 라이브러리 및 샘플 앱 다운로드 섹션에 설명된 대로 모의 라이브러리와 샘플 앱을 다운로드합니다.

개발자 센터 베타 앱을 만들거나 모의 앱에서 바로 구매 라이브러리를 솔루션에 추가하여 앱에서 바로 구매를 테스트하는 대신 Microsoft IIS(인터넷 정보 서비스)를 사용하여 앱에서 바로 구매 모의 서비스를 설정할 수도 있습니다.

Visual Studio를 사용하면 Windows Phone 에뮬레이터를 사용하여 앱의 앱에서 바로 구매 동작을 테스트할 수 있습니다. Windows Phone 에뮬레이터는 로컬 컴퓨터에 배포되거나 에뮬레이터에서 액세스할 수 있는 서버에 배포되는 모의 서비스에 연결됩니다.

모의 서비스를 사용하여 앱에서 바로 구매를 테스트하는 이점

앱에서 바로 구매 모의 서비스는 다음과 같은 이점을 제공합니다.

  • Windows Phone 에뮬레이터를 사용하여 개발 프로세스 중에 앱에서 바로 구매의 종단 간 흐름을 테스트할 수 있습니다.

  • 데이터를 개발자 센터 에 제출하거나 이 솔루션 함수를 포함하도록 코드를 변경할 필요가 없습니다.

  • 제품 구성 변경 및 앱과 통합을 빠르게 반복할 수 있습니다.

  • 앱과 Windows Phone 플랫폼 간의 플랫폼 상호 작업을 시뮬레이션할 수 있습니다.

다음 다이어그램에서는 앱에서 바로 구매 모의 서비스를 사용할 경우 관련된 작업을 보여 줍니다.

Mock Service

이전 다이어그램의 각 흐름은 다음 목록에 설명되어 있습니다.

  • A) 모의 서비스 배포: IIS에서 모의 서비스를 다운로드하고 설정합니다.

  • B) 제품 목록 추가: 앱을 테스트할 모의 제품 목록(카탈로그)을 추가하고 구성합니다.

  • C) 제품 나열: 모의 제품 목록을 검색합니다.

  • D) 제품 구매: 구매할 모의 제품을 선택하고 모의 서비스에서 구매합니다.

  • E) 라이선스 열거: 앱에서 제품에 사용 가능한 모든 라이선스를 열거하고 제품이 이미 사용이 허가되었는지 여부 또는 일부 제품의 주문 처리가 필요한지 여부를 결정합니다.

  • F) 승인된 주문 처리: 모의 제품이 성공적으로 구매되었음을 승인합니다.

  • G) 영수증 받기: 구매한 모든 모의 제품의 영수증을 수령합니다.

  • H) 주문 처리: (선택 사항) 서버에서 디지털 콘텐츠를 다운로드합니다.

  • I) 라이선스 영수증 보내기: (선택 사항) 구매 주문 처리에 디지털 콘텐츠가 필요한 경우 소유하거나 관리하는 서비스를 통해 이 콘텐츠를 다운로드하면 구매에 대한 디지털 방식으로 서명된 영수증이 서버로 전달됩니다.

사전 요구 사항

시작하기 전에 다음 소프트웨어가 컴퓨터에 설치되어 있는지 확인하세요.

  • Visual Studio 2010 이상 버전

  • IIS 7 및 ASP.NET 4.5

    설치 단계에 대해서는 IIS 및 ASP.NET 모듈 설치를 참조하세요.

  • 웹 배포

    모의 서비스 배포 패키지를 배포하려면 배포 파일을 실행하는 컴퓨터에 웹 배포(msdeploy.exe)를 설치해야 합니다. 웹 배포 설치 방법에 대한 자세한 내용은 웹 배포 소개를 참조하세요.

WCF 서비스용 HTTP 활성화를 설치하고 IIS로의 HTTP 요청에 대해 방화벽 예외를 만들어야 할 수도 있습니다. 자세한 내용은 Windows Phone 8 에뮬레이터에서 로컬 웹 서비스에 연결하는 방법을 참조하세요.

에뮬레이터 설정

에뮬레이터를 설정하려면 다음 단계가 필요합니다.

  1. 로컬 컴퓨터에 모의 서비스를 배포합니다.

  2. 모의 서비스에 연결할 에뮬레이터를 구성합니다.

  3. 앱에서 사용되도록 제품 카탈로그를 구성합니다.

  4. 앱 매니페스트를 업데이트하여 특정 APP ID를 사용합니다.

1단계 - 로컬 컴퓨터에 모의 서비스 배포

다음 배포 단계에서는 모의 카탈로그 서비스 배포 패키지를 다운로드하고 설정합니다.

모의 카탈로그 서비스 배포 패키지 다운로드

모의 카탈로그 서비스를 IIS에 배포하려면 모의 카탈로그 서비스 배포 패키지를 다운로드해야 합니다. 이 패키지는 모의 카탈로그 서비스 소스 코드에 zip 파일로 포함되어 있습니다.

참고참고:

사용자 지정 배포 시나리오의 경우 모의 카탈로그 서비스 소스 코드를 다운로드하여 수정합니다.

IIS에서 모의 서비스 설정

  1. IIS 관리자를 엽니다.

  2. 연결 창에서 계층 구조의 사이트 노드를 마우스 오른쪽 버튼으로 클릭하고 웹 사이트 추가를 클릭합니다.

  3. 웹 사이트 추가 대화 상자에서 사이트 이름을 다음으로 설정합니다.

    IAPCatalogMockService

  4. 실제 경로를 다음으로 설정합니다.

    <path>\IapcatalogMockService\CatalogMockService

  5. IIS_IUSRS가 액세스할 수 있도록 사이트가 배포되는 폴더의 권한을 설정합니다.

  6. 다음 단계에 따라 IAPCatalogMockService 사이트를 사용하는 CatalogMock 서비스 패키지를 배포합니다.

    1. 관리자 권한으로 명령 프롬프트 창을 엽니다.

    2. Mock-Project-Deployment Package\Deployment Package 폴더를 엽니다.

    3. 명령 프롬프트에서 다음을 입력하여 모의 서비스를 배포합니다.

      CatalogServiceMockDeploymentPackage.deploy.cmd /Y

IIS에 대한 자세한 내용은 웹 사이트 만들기(IIS 7)를 참조하세요. 모의 서비스에 관련된 배포 지침은 CatalogServiceMockDeploymentPackage.deploy-readme.txt 파일에서 사용할 수 있습니다.

모의 서비스가 사용 가능하고 제대로 배포되었는지 확인

  1. 다음 GET 요청을 실행하여 지원되는 명령 목록을 가져옵니다.

    http://localhost/v8/help

    응답에는 다음 항목이 포함되어야 합니다.

    URI

    메서드

    설명

    /catalog/apps/{appid}

    GET

    Service at http://localhost/v8/catalog/apps/{APPID}

    /catalog/apps/{appid}/iaps

    POST

    Service at http://localhost/v8/catalog/apps/{APPID}/iaps

    /images/{imageid}

    GET

    Service at http://localhost/v8/images/{IMAGEID}

  2. 다음 GET 요청을 수행하여 반환된 미리 구성된 이미지를 볼 수 있습니다.

    http://[machine IP address]/v8/images/102a19e4-e6f2-495a-acc7-203bb6c742b9?imagetype=icon_iap

    참고참고:

    명령 창(cmd.exe)에서 ipconfig를 입력하여 컴퓨터 IP 주소를 검색할 수 있습니다.

    Windows IP Configuration이 명령 창에 표시됩니다. Ethernet adapter vEthernet (Internal Ethernet Port Windows Phone Emulator Internal Switch) 섹션에서 IPv4 Address 옆에 있는 IP 주소를 찾습니다.

    Testcalls.txt 파일을 검토하여 서비스가 처리할 기타 호출을 확인합니다. Testcalls.txt 파일은 다운로드 패키지의 루트에 있습니다. 자세한 내용은 모의 카탈로그 서비스 배포 패키지 다운로드를 참조하세요.

2단계 - 모의 카탈로그 서비스와 연결할 에뮬레이터 구성

이 섹션에서는 서버에 배포한 모의 서비스에 연결할 Windows Phone 에뮬레이터를 구성하는 방법에 대해 설명합니다. Windows Phone 에뮬레이터를 설정한 동일한 컴퓨터에 모의 서비스를 배포한 경우에는 에뮬레이터와 연결된 IP 주소를 가져와야 합니다. 이 섹션에서는 에뮬레이터와 연결된 IP 주소를 가져오는 방법에 대해 설명합니다.

다음 단계에 따라 에뮬레이터로 모의 서비스를 가리킵니다.

  1. 아직 설치되지 않은 경우 Windows Phone SDK 8.0 을(를) 설치합니다.

  2. VHD에서 read-only 플래그를 제거합니다.

    1. 파일 탐색기를 열고 C:\Program Files (x86)\Microsoft SDKs\Windows Phone\v8.0\Emulation\Images으로 이동합니다.

    2. 각 차등 VHD의 읽기 전용 특성을 제거합니다. 예를 들어 파일 Flash.480x800.vhd를 마우스 오른쪽 버튼으로 클릭하고 속성을 클릭합니다. 읽기 전용을 선택 취소하고 확인을 누릅니다.

  3. 디스크 관리를 엽니다.

    • 작업, VHD 연결을 차례로 선택하여 새 시각적 하드 드라이브(디스크)를 컴퓨터에 마운트합니다.

      사용하려는 각 지원되는 해상도에 대해 이 단계를 반복합니다.

  4. 다음 단계를 수행하여 HOSTS 파일이 포함된 Windows 파티션을 찾습니다.

    1. 파일 탐색기를 사용하여 [드라이브]\Windows\System32\drivers\etc에 있는 etc 폴더로 이동합니다.

    2. 메모장관리자 권한으로 엽니다.

    3. 메모장에서 파일 탐색기에 있는 경로에 따라 HOST 파일을 엽니다.

    4. 다음 형식에 따라 진입점을 HOST 파일에 추가합니다.

      #<에뮬레이터 모의 서비스의 IP 주소> marketplaceedgeservice.windowsphone.com

      중요중요:

      모의 서비스가 제대로 작동하도록 이 단계를 따라야 합니다.

    5. 파일을 저장합니다. 파일을 .txt 파일로 저장하지 않아야 합니다.

  5. 디스크를 마우스 오른쪽 버튼으로 클릭하고 VHD 분리를 선택하여 이전에 만든 VHD 디스크를 분리합니다.

  6. Hyper-V 관리자를 사용하여 다음 단계에 따라 VHD의 캐시된 복사본을 제거합니다.

    1. Hyper-V 관리자를 실행합니다.

    2. 로컬 컴퓨터에 연결합니다.

      가상 컴퓨터가 나열됩니다. 에뮬레이터 WVGA.%computername%을 찾습니다.

    3. 에뮬레이터가 닫히지 않은 경우 종료를 마우스 오른쪽 버튼으로 클릭합니다.

    4. 삭제를 마우스 오른쪽 버튼으로 클릭합니다.

  7. Windows Phone 앱에서 에뮬레이터를 실행할 경우 위의 호스트 파일을 업데이트한 VHD에 대해 동일한 에뮬레이터를 실행해야 합니다.

3단계 - 사용할 앱의 제품 카탈로그 구성

연결된 XML을 수정하여 앱에서 바로 구매 제품 카탈로그를 구성합니다. 모의 서비스가 배포된 폴더에서 iapcatalog.xml이라는 XML 파일을 찾습니다.

모의 서비스는 XML을 입력으로 사용합니다. 서비스는 앱 디렉터리 경로에 따라 이 XML 파일(iapcatalog.xml)을 읽습니다.

XML은 다음과 같이 형식이 지정됩니다.

<Catalog>
  <Item> 
    <ProductId>Test1</ProductId> <!—The unique Product Identifier -->
    <Title>Test Item 1</Title> 
    <Description>This is a test item</Description>
    <Type>iapconsumable</Type>
    <Tag>
      { Order: 1, Rewards: [ { Name: 'Credits', Quantity: 100 }, { Name: 'Coins', Quantity: 10000 } ] }
    </Tag>
  </Item>
</Catalog>

제품 카탈로그 XML 파일의 요소에 대한 자세한 내용은 앱 내 제품 속성을 참조하세요.

4단계 - 매니페스트를 업데이트하여 특정 APP ID 사용

앱의 매니페스트 파일을 업데이트하여 모의 서비스와 통신하는 데 사용한 APP ID를 사용합니다.

Visual Studio에서 값을 다음과 같이 업데이트합니다.

ee29a261-80d0-4bdf-89bd-28b1ebbc8bd3

앱 실행

이제 테스트 모드에서 앱을 실행할 수 있습니다. 앱이 스토어 서비스를 호출하지 않고 모의 서비스를 호출합니다.

이 정보가 도움이 되었습니까?
(1500자 남음)
의견을 주셔서 감사합니다.
표시:
© 2014 Microsoft. All rights reserved.